Mysql查询慢日志

Mysql 的慢查询日志是Mysql提供的一种日志记录,它用来记录在mysql中响应时间超过阈值的语句,具体指运行时间超过long_query_time 值的slq,则会被记录到慢查询日志中。

默认情况下,mysql数据库没有开启慢查询日志,需要我们手动来设置这个参数:

1
2
3
4
5
6
# 开启慢查询日志
slow_query_log = on
# 设置慢查询日志存放路径
slow-query-log-file = /usr/local/mysql/var/slow_query.log
# 设置慢查询时间
long_query_time = 2

long_query_time 默认是10 ,意思是运行10秒以上的语句。

1
2
3
4
5
6
7
mysql> SHOW VARIABLES LIKE 'long_query_time%';
+-----------------+----------+
| Variable_name | Value |
+-----------------+----------+
| long_query_time | 2.000000 |
+-----------------+----------+
1 row in set (0.01 sec)

开启慢查询日志功能后,可以通过mysqldumpslow来分析慢查询日志。

命令:

1
2
3
4
5
6
7
8
9
-s 按照那种方式排序
c:访问计数
l:锁定时间
r:返回记录
al:平均锁定时间
ar:平均访问记录数
at:平均查询时间
-t 是top n的意思,返回多少条数据。
-g 可以跟上正则匹配模式,大小写不敏感。

得到返回记录最多的20个sql:

mysqldumpslow -s r -t 20 slow_query.log

得到平均访问次数最多的20条sql:

mysqldumpslow -s ar -t 20 slow_query.log

得到平均访问次数最多,并且里面含有ttt字符的20条sql:

mysqldumpslow -s ar -t 20 -g “ttt” slow_query.log

有用就打赏一下作者吧!