慢查询日志功能
show variables like 'slow_query_log';
show variables like 'slow_query_log_file';
show variables like 'long_query_time';
set global slow_query_log = on;
[mysqld]
slow_query_log=1
slow_query_log_file=/var/lib/mysql/data/hostname-slow.log
long_query_time=10
log_output=FILE
- Mysql的慢查询日志是Mysql提供的一种日志记录,它用来记录在Mysql中响应时间超过阀值的语句,具体指运行时间超过long_query_time值的SQL(“等于”是不会被记录的),则会被记录到慢查询日志中。
- long_query_time的默认值为10,意思是运行10秒以上的语句。
- 由此来查看哪些SQL超出了我们的最大忍耐时间,比如一条sql执行超过5秒,我们就算慢sql,希望能收集超过5秒的sql,结合explain进行全面分析。
- 默认情况下,Mysql数据库没有开启慢查询,需要手动来设置这个参数。
- 如果不是调优需要的话,一般不建议启动该参数,因为开启慢查询日志会带来一定的性能影响。
- 慢查询日志支持将日志记录写入文件,或者写入表中。
慢查询日志分析工具(mysqldumpslow)
mysqldumpslow --help
mysqldumpslow -s r -t 10 /var/lib/mysql/data/hostname-slow.log
mysqldumpslow -s c -t 10 /var/lib/mysql/data/hostname-slow.log
mysqldumpslow -s t -t 10 -g "lsef join" /var/lib/mysql/data/hostname-slow.log
mysqldumpslow -s r -t 10 /var/lib/mysql/data/hostname-slow.log | more