|
启用 slow log
有两种启用方式:1, 在my.cnf 里 通过 log-slow-queries[=file_name] 2, 在mysqld进程启动时,指定--log-slow-queries[=file_name]选项比较的五款常用工具
mysqldumpslow, mysqlsla, myprofi, mysql-explain-slow-log, mysqllogfilter mysqldumpslow, mysql官方提供的慢查询日志分析工具. 输出图表如下:
![](/d/file/itjie/<a href=/itjie/phpjishu/ target=_blank class=infotextkey>php</a>jishu/2014-10-22/47b74df8f764fe82dbd888cad4371810.gif)
mysqlsla, hackmysql.com推出的一款日志分析工具(该网站还维护了 mysqlreport, mysqlidxchk 等比较实用的mysql工具)
![](/d/file/itjie/<a href=/itjie/phpjishu/ target=_blank class=infotextkey>php</a>jishu/2014-10-22/dc8a3406d1857a53ba5df76cfd20d175.gif)
格式说明如下:总查询次数 (queries total), 去重后的sql数量 (unique)输出报表的内容排序(sorted by)最重大的慢sql统计信息, 包括 平均执行时间, 等待锁时间, 结果行的总数, 扫描的行总数.
Count, sql的执行次数及占总的slow log数量的百分比.Time, 执行时间, 包括总时间, 平均时间, 最小, 最大时间, 时间占到总慢sql时间的百分比.95% of Time, 去除最快和最慢的sql, 覆盖率占95%的sql的执行时间.Lock Time, 等待锁的时间.95% of Lock , 95%的慢sql等待锁时间.Rows sent, 结果行统计数量, 包括平均, 最小, 最大数量.
Rows examined, 扫描的行数量.Database, 属于哪个数据库Users, 哪个用户,IP, 占到所有用户执行的sql百分比
Query abstract, 抽象后的sql语句Query sample, sql语句
除了以上的输出, 官方还提供了很多定制化参数, 是一款不可多得的好工具.
mysql-explain-slow-log, 德国人写的一个perl脚本.
http://www.willamowius.de/mysql-tools.html
![](/d/file/itjie/<a href=/itjie/phpjishu/ target=_blank class=infotextkey>php</a>jishu/2014-10-22/eb17fcd5ad0b7724151ec92066ed6410.gif)
![](/d/file/itjie/<a href=/itjie/phpjishu/ target=_blank class=infotextkey>php</a>jishu/2014-10-22/14b9375c44e612236d21e471aec48601.gif)
http://code.google.com/p/mysql-log-filter/
![](/d/file/itjie/<a href=/itjie/phpjishu/ target=_blank class=infotextkey>php</a>jishu/2014-10-22/ba62063c6a430f4e0c9ac6514104c976.gif)
特色功能除了统计信息外, 还针对输出内容做了排版和格式化, 保证整体输出的简洁. 喜欢简洁报表的朋友, 推荐使用一下.myprofi, 纯php写的一个开源分析工具.项目在 sourceforge 上.
http://myprofi.sourceforge.NET/
![](/d/file/itjie/<a href=/itjie/phpjishu/ target=_blank class=infotextkey>php</a>jishu/2014-10-22/615ba8e0fecdd4f561a973fc9172b28c.gif)
从整体输出样式来看, 比mysql-log-filter还要简洁. 省去了很多不必要的内容. 对于只想看sql语句及执行次数的用户来说, 比较推荐.
总结
工具/功能 | 一般统计信息 | 高级统计信息 | 脚本 | 优势 |
mysqldumpslow | 支持 | 不支持 | perl | mysql官方自带 |
mysqlsla | 支持 | 支持 | perl | 功能强大,数据报表齐全,定制化能力强. |
mysql-explain-slow-log | 支持 | 不支持 | perl | 无 |
mysql-log-filter | 支持 | 部分支持 | Python or php | 不失功能的前提下,保持输出简洁 |
myprofi | 支持 | 不支持 | php | 非常精简 |
php技术:五款常用mysql slow log分析工具的比较分析,转载需保留来源!
郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。