Mysql 的慢查询日志是Mysql提供的一种日志记录,它用来记录在mysql中响应时间超过阈值的语句,具体指运行时间超过long_query_time 值的slq,则会被记录到慢查询日志中。
long_query_time 默认是10 ,意思是运行10秒以上的语句。
由他来查看哪些sql超出了我们的最大忍耐时间值,比如一条sql执行超过5秒,我们就算慢sql,希望能收集超过5秒的sql,结合之前explain进行全面分析。
默认情况下,mysql数据库没有开启慢查询日志,需要我们手动来设置这个参数。
当然,如果不是调优需要的话,一般不建议启动该参数,因为开启慢查询日志会或多或少带来一定的性能影响。慢查询日志支持将日志记录写入文件。
日志存储文件
show variables like '%slow_query_log%';
开启慢日志:重启会失效
set global slow_query_log=1;
如果要永久生效,就必须修改配置文件my.cnf(其它系统变量也是如此)
修改my.cnf文件,[mysqld]下增加或修改参数
将如下两行配置进my.cnf文件
slow_query_log =1
slow_query_log_file=/var/run/mysqld/mysqld-slow.log
SHOW VARIABLES LIKE 'long_query_time%';
默认10秒
10秒?等不起,设置阈值3秒钟的就是慢
set global long_query_time=3;
需要新开一个会话,才能看到修改值
设置一条慢查询:
查看慢sql条数:
select sleep(4);
show global status like '%Slow_queries%';
慢日志 库 sql抓取 :查看慢查询日志
mysqldumpslow :日志抓取命令
得到返回记录集最多的10个sql
mysqldumpslow -s r -t 10 /var/run/mysqld/mysqld-slow.log
得到访问次数最多的10个sql
mysqldumpslow -s c -t 10 /var/run/mysqld/mysqld-slow.log
得到按照时间排序的前10条里面含有左连接的查询语句
mysqldumpslow -s t -t 10 -g “left join” /var/run/mysqld/mysqld-slow.log
另外建议在使用这些命令时结合|和more使用,否则有可能出现爆屏情况
mysqldumpslow -s r -t 10 /var/run/mysqld/mysqld-slow.log | more