五款常用mysql slow log分析工具的比较分析


Posted in PHP onMay 22, 2011

启用 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官方提供的慢查询日志分析工具. 输出图表如下:
五款常用mysql slow log分析工具的比较分析
主要功能是, 统计不同慢sql的
出现次数(Count), 
执行最长时间(Time), 
累计总耗费时间(Time), 
等待锁的时间(Lock), 
发送给客户端的行总数(Rows), 
扫描的行总数(Rows), 
用户以及sql语句本身(抽象了一下格式, 比如 limit 1, 20 用 limit N,N 表示).

mysqlsla, hackmysql.com推出的一款日志分析工具(该网站还维护了 mysqlreport, mysqlidxchk 等比较实用的mysql工具)
五款常用mysql slow log分析工具的比较分析
整体来说, 功能非常强大. 数据报表,非常有利于分析慢查询的原因, 包括执行频率, 数据量, 查询消耗等.

格式说明如下:
总查询次数 (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

五款常用mysql slow log分析工具的比较分析
五款常用mysql slow log分析工具的比较分析
功能上有点瑕疵, 不仅把所有的 slow log 打印到屏幕上, 而且统计也只有数量而已. 不推荐使用.
mysql-log-filter, google code上找到的一个分析工具.提供了 python 和 php 两种可执行的脚本.
http://code.google.com/p/mysql-log-filter/
五款常用mysql slow log分析工具的比较分析
功能上比官方的mysqldumpslow, 多了查询时间的统计信息(平均,最大, 累计), 其他功能都与 mysqldumpslow类似.
特色功能除了统计信息外, 还针对输出内容做了排版和格式化, 保证整体输出的简洁. 喜欢简洁报表的朋友, 推荐使用一下.
myprofi, 纯php写的一个开源分析工具.项目在 sourceforge 上.
http://myprofi.sourceforge.net/

 五款常用mysql slow log分析工具的比较分析

功能上, 列出了总的慢查询次数和类型, 去重后的sql语句, 执行次数及其占总的slow log数量的百分比.
从整体输出样式来看, 比mysql-log-filter还要简洁. 省去了很多不必要的内容. 对于只想看sql语句及执行次数的用户来说, 比较推荐.

总结

工具/功能 一般统计信息 高级统计信息 脚本 优势
mysqldumpslow 支持 不支持 perl mysql官方自带
mysqlsla 支持 支持 perl 功能强大,数据报表齐全,定制化能力强.
mysql-explain-slow-log 支持 不支持 perl
mysql-log-filter 支持 部分支持 python or php 不失功能的前提下,保持输出简洁
myprofi 支持 不支持 php 非常精简
PHP 相关文章推荐
PHP 递归效率分析
Nov 24 PHP
PHP中return 和 exit 、break和contiue 区别与用法
Apr 09 PHP
解析mysql 表中的碎片产生原因以及清理
Jun 22 PHP
解析如何修改phpmyadmin中的默认登陆超时时间
Jun 25 PHP
PHP页面中文乱码分析
Oct 29 PHP
PHP中$_FILES的使用方法及注意事项说明
Feb 14 PHP
php使用gzip压缩传输js和css文件的方法
Jul 29 PHP
php使用SAE原生Mail类实现各种类型邮件发送的方法
Oct 10 PHP
Laravel框架定时任务2种实现方式示例
Dec 08 PHP
解决laravel-admin 自己新建页面里 js 需要刷新一次的问题
Oct 03 PHP
PHP PDO和消息队列的个人理解与应用实例分析
Nov 25 PHP
Laravel6.18.19如何优雅的切换发件账户
Jun 14 PHP
php性能优化分析工具XDebug 大型网站调试工具
May 22 #PHP
Look And Say 序列php实现代码
May 22 #PHP
php利用cookie实现访问次数统计代码
May 19 #PHP
PHP操作mysql函数详解,mysql和php交互函数
May 19 #PHP
php异常:Parse error: syntax error, unexpected T_ENCAPSED_AND_WHITESPACE  eval()'d code error
May 19 #PHP
php中全局变量global的使用演示代码
May 18 #PHP
一个PHP分页类的代码
May 18 #PHP
You might like
聊天室php&mysql(五)
2006/10/09 PHP
php类中的$this,static,final,const,self这几个关键字使用方法
2015/12/14 PHP
PHP 使用二进制保存用户状态的实例
2018/01/29 PHP
javascript检测页面是否缩放的小例子
2013/05/16 Javascript
jquery和ajax的关系详细介绍
2013/11/29 Javascript
解决node-webkit 不支持html5播放mp4视频的方法
2015/03/11 Javascript
jQuery使用hide方法隐藏指定元素class样式用法实例
2015/03/30 Javascript
javascript格式化日期时间方法汇总
2015/06/19 Javascript
jQuery模拟select实现下拉菜单功能
2016/06/20 Javascript
Wireshark基本介绍和学习TCP三次握手
2016/08/15 Javascript
前端 Vue.js 和 MVVM 详细介绍
2016/12/29 Javascript
利用jquery正则表达式在页面验证url网址输入是否正确
2017/04/04 jQuery
详细讲解vue2+vuex+axios
2017/05/27 Javascript
Node.js+Express+MySql实现用户登录注册功能
2017/07/10 Javascript
vue-router路由懒加载的实现(解决vue项目首次加载慢)
2018/08/28 Javascript
2种在vue项目中使用百度地图的简单方法
2018/09/28 Javascript
编写一个javascript元循环求值器的方法
2020/04/14 Javascript
[05:09]第二届DOTA2亚洲邀请赛决赛日比赛集锦:iG 3:0 OG夺冠
2017/04/05 DOTA
[28:05]完美世界DOTA2联赛循环赛Inki vs DeMonsTer 第一场 10月30日
2020/10/31 DOTA
Python中的闭包实例详解
2014/08/29 Python
Python中的字符串查找操作方法总结
2016/06/27 Python
使用python存储网页上的图片实例
2018/05/22 Python
对python创建及引用动态变量名的示例讲解
2018/11/10 Python
python对象转字典的两种实现方式示例
2019/11/07 Python
Django 简单实现分页与搜索功能的示例代码
2019/11/07 Python
python-web根据元素属性进行定位的方法
2019/12/13 Python
使用SimpleITK读取和保存NIfTI/DICOM文件实例
2020/07/01 Python
opencv python 对指针仪表读数识别的两种方式
2021/01/14 Python
HTML5 Canvas中绘制椭圆的4种方法
2015/04/24 HTML / CSS
祖国在我心中演讲稿
2014/01/15 职场文书
计算机毕业生自荐信
2014/06/12 职场文书
校友回访母校寄语
2015/02/26 职场文书
工作年限证明模板
2015/06/15 职场文书
出生证明范本
2015/06/15 职场文书
SQL Server连接查询的实用教程
2021/04/07 SQL Server
详解Django中 render() 函数的使用方法
2021/04/22 Python