MySQL相关
查看是否开启慢SQL
show variables like '%slow_query_log%';
开启慢查询日志
set global slow_query_log='ON';
查看慢查询阈值
show variables like '%long_query_time%';
设置慢查询阈值
set global long_query_time=1;
set long_query_time=1;
设置global的方式对当前session
的long_query_time
失效,对新连接的客户端有效。
查看慢查询日志路径
show variables like '%slow_query_log_file%';
查看慢查询数目
show global status like '%slow_queries%';
慢查询日志分析工具 mysqldumpslow
要手工分析日志,查找、分析SQL,显然是个体力活,MySQL提供了日志分析工具 mysqldumpslow 。
mysqldumpslow 命令的具体参数如下:
- -a: 不将数字抽象成N,字符串抽象成S
- -s: 是表示按照何种方式排序:
- c: 访问次数
- l: 锁定时间
- r: 返回记录
- t: 查询时间
- al:平均锁定时间
- ar:平均返回记录数
- at:平均查询时间 (默认方式)
- ac:平均查询次数
- -t: 即为返回前面多少条的数据;
- -g: 后边搭配一个正则匹配模式,大小写不敏感的;
mysqldumpslow在mysql的bin目录下,以通过执行 mysqldumpslow --help
命令查看使用。
常见的用法
# 按照查询时间排序,查看前五条 SQL 语句
mysqldumpslow -s t -t 5 /usr/local/mysql/data/alvin-slow-slow.log
# 得到返回记录集最多的10个SQL
mysqldumpslow -s r -t 10 /usr/local/mysql/data/alvin-slow-slow.log
# 得到访问次数最多的10个SQL
mysqldumpslow -s c -t 10 /usr/local/mysql/data/alvin-slow-slow.log
# 得到按照时间排序的前10条里面含有左连接的查询语句
mysqldumpslow -s t -t 10 -g "left join" /usr/local/mysql/data/alvin-slow-slow.log
# 另外建议在使用这些命令时结合 | 和more 使用 ,否则有可能出现爆屏情况
mysqldumpslow -s r -t 10 /usr/local/mysql/data/alvin-slow-slow.log | more
删除慢SQL日志
手动删除
用 rm
命令删除慢查询日志文件。
mysqladmin
mysqladmin -uroot -p flush-logs slow