设置记录的阈值:
set global long_query_time=3;
设置了但是还是没有发生更改?为什么?此时需要重新开启一个会话才可以:
接下来实行一个较慢的查询,如下图,但是记得要在配置文件中做如下配置:
接着去日志文件中查看存在哪些超过阈值的SQL就好了:
查询当前系统中有多少条慢查询记录:
记载一下我的配置文件
slow_query_log=1; slow_query_log_file=/var/lib/mysql/tim-slow.log; long_query_time=3; log_output=FILE
日志分析工具mysqldumpshow
在生产环境中,如果要手工分析日志,查找、分析 SQL,显然是个体力活,MYSQL 提供了日志分析工具mysqldumpshow
- s:是表示按何种方式排序
- c:访问次数
- l:锁定时间
- r:返回记录
- t:查询时间
- al:平均锁定时间
- ar:平均返回记录数
- at:平均查询时间
- t:即为返回前面多少条的数据
- g:后边搭配一个正则匹配模式,大小写不敏感的
下面是使用示例:
得到返回记录集最多的 10 个 SQL
mysqldumpslow -s r -t 10 /var/lib/mysql/tim-slowlog
得到访问次数最多的 10 个 SQL
mysqldumpslow -s c-t 10 /var/lib/mysql/tim-slow log
得到按照时间排序的前 10 条里面含有左连接的查询语句
mysqldumpslow -s t -t 10 -g "left join" /var/lib/mysql/tim-slowlog
另外建议在使用这些命令时结合和 more 使用,否则有可能出现爆屏情況
mysqldumpslow -s r -t 10 /var/lib/mysq/tim-slow.log | more
以上就是MySQL 慢查询日志深入理解的详细内容,更多关于MySQL 慢查询日志的资料请关注其它相关文章!
更多相关Mysql内容来自木庄网络博客
标签:Mysql
相关阅读 >>
更多相关阅读请进入《mysql》频道 >>

数据库系统概念 第6版
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。