MySQL慢查询日志收集、定位,慢查询分析、排查。
一 MySQL慢查询定位
1. 确定是否已开启慢查询日志
查看慢查询日志是否已经被开启:
SHOW VARIABLES LIKE 'slow_query_log';
如果返回值是'OFF',你需要开启它。
2. 开启慢查询日志
你可以临时在运行中的MySQL实例中开启慢查询日志:
SET GLOBAL slow_query_log = 'ON';
或者你可以在`my.cnf`(或`my.ini`)配置文件中,加入以下设置,然后重启MySQL来永久开启它:
slow_query_log = 1slow_query_log_file = /path/to/your/logfile.log # 指定慢查询日志的路径
3. 设置慢查询的阈值
默认情况下,超过10秒的查询会被记录为慢查询。但你可以根据实际需求调整这个阈值:
SET GLOBAL long_query_time = X; # X是你想设置的秒数
或在`my.cnf`中设置:
long_query_time = X
4. 开启全查询日志(非必须)
默认情况下,只有不使用索引的查询才会被记录。如果你想记录所有查询,可以设置:
SET GLOBAL log_queries_not_using_indexes = 'ON';
5. 查看慢查询日志
等待一段时间后,可以查看`/path/to/your/logfile.log`来定位慢查询。
6. 分析慢查询日志
你可以手动查看日志,或者使用工具如`mysqldumpslow`来帮助分析日志内容。
使用`mysqldumpslow`可以按照不同的维度(如执行时间、平均查询时长等)对慢查询进行排序和分析:<

最低0.47元/天 解锁文章


被折叠的 条评论
为什么被折叠?



