mysql慢查询工具
1、在控制台查找慢查询工具(也可以放在第三步)
-- 查找慢查询工具
find / -name mysqldumpslow
2、在mysql页面查看慢查询信息
-- 查询是否开启慢查询日志,value为OFF,则没开启
show variables like 'slow_query_log'
-- 如果没有开启慢查询日志
set global slow_query_log = on;
-- 临时设置慢查询时间临界点,如设为5秒
set long_query_time = 5;
-- 设置慢查询存储的方式为文件
set global log_output = file;
-- 查询慢查询日志的开启状态和慢查询日志储存的位置,slow_query_log_file那行
show variables like '%quer%';
3、用慢查询工具分析慢查询日志
样例:
-- 工具 指令 慢查询日志:查找最慢的sql(排序)
/usr/bin/mysqldumpslow -s -t /var/lib/mysql/slow_query.log
使用命令查找mysqldumpslow工具路径
find / -name mysqldumpslow
我的查询返回路径为:
/usr/local/mysql/bin/mysqldumpslow
访问次数最多的10条sql语句
[mysqldumpslow工具目录/工具] -s c -t 10 [mysql_slow_querys.log目录/log文件]
返回记录最多的20条sql语句
[mysqldumpslow工具目录/工具] -s r -t 10 [mysql_slow_querys.log目录/log文件]
按照时间返回前10条里面含有left join的sql语句
[mysqldumpslow工具目录/工具] -t 10 -s t -g “left join” [mysql_slow_querys.log目录/log文件]
``` |
**使用命令查看mysqldumpslow参数说明**
```shell
[mysqldumpslow工具目录/工具] -help |
mysqldumpslow常用参数
-s,是order的顺序,说明写的不够详细,主要有 c,t,l,r和ac,at,al,ar,分别是按照query次数,时间,lock的时间和返回的记录数来排序,前面加了a的时倒序
-t,是top n的意思,即为返回前面多少条的数据
-g,后边可以写一个正则匹配模式,大小写不敏感的 |
mysqldumpslow完整参数说明如下: --verbose verbose --debug debug --help write this text to standard output
-v verbose -d debug -s ORDER what to sort by (al, at, ar, c, l, r, t), 'at' is default al: average lock time ar: average rows sent at: average query time c: count l: lock time r: rows sent t: query time -r reverse the sort order (largest last instead of first) -t NUM just show the top n queries -a don't abstract all numbers to N and strings to 'S' -n NUM abstract numbers with at least n digits within names -g PATTERN grep: only consider stmts that include this string -h HOSTNAME hostname of db server for -slow.log filename (can be wildcard), default is '', i.e. match all -i NAME name of server instance (if using mysql.server startup script) -l don't subtract lock time from total time