霜天部落 | 专注PHP研发,研究LAMP高性能架构部署与优化

mysql慢查询记录(slow log)脚本分析

mysql有一个功能是可以LOG记录运行的比较慢的sql语句。但默认是没有这个log记录的,要修改my.cnf或者在mysql启动的时候加入一些参数才能开启这个功能。如果在my.cnf里面修改的话,要增加下面几行代码:

long_query_time = 2

log-slow-queries = /var/path/slow.log

log-queries-not-using-indexes

long_query_time 是指执行超过多久的sql会被log下来,这里是1秒。

log-slow-queries 设置把日志写在那里,可以为空,系统会给一个缺省的文件host_name-slow.log

log-queries-not-using-indexes 就是字面意思,log下来没有使用索引的query。

把上述参数打开,运行一段时间,就可以关掉了。

接下来就是分析了,这里的文件名字叫 sql-slow.log。

先mysqldumpslow –help以下,它主要用的是

-s ORDER what to sort by (t, at, l, al, r, ar etc), ‘at’ is default
-t NUM just show the top n queries
-g PATTERN grep: only consider stmts that include this string

解释一下:

-s,是order的顺序,说明写的不够详细,主要有c,t,l,r和ac,at,al,ar,分别是按照query次数,时间,lock的时间和返回的记录数来排序,前面加了a的时倒序
-t,是top n的意思,即为返回前面多少条的数据
-g,后边可以写一个正则匹配模式,大小写不敏感的

mysqldumpslow -s c -t 20 sql-slow.log
mysqldumpslow -s r -t 20 sql-slow.log

上述命令可以看出访问次数最多的20个sql语句和返回记录集最多的20个sql。

mysqldumpslow -t 10 -s t -g “left join” sql-slow.log

这个是按照时间返回前10条里面含有左连接的sql语句。用了这个工具就可以查询出来那些sql语句是性能的瓶颈,进行优化。

以上就是“mysql慢查询记录(slow log)脚本分析”的内容。