五款常用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教程孙仲岳主讲
Jan 07 PHP
php error_log 函数的使用
Apr 13 PHP
php导出excel格式数据问题
Mar 11 PHP
php实现的zip文件内容比较类
Sep 24 PHP
php+mysql查询优化简单实例
Jan 13 PHP
Symfony2学习笔记之系统路由详解
Mar 17 PHP
PHP通过引用传递参数用法分析
Dec 01 PHP
phpcms的分类名称和类别名称的调用
Jan 05 PHP
Yii2使用$this->context获取当前的Module、Controller(控制器)、Action等
Mar 29 PHP
PHP常见加密函数用法示例【crypt与md5】
Jan 27 PHP
php写入文件不覆盖的实例讲解
Sep 17 PHP
浅析PHP反序列化中过滤函数使用不当导致的对象注入问题
Feb 15 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中的HashTable结构详解
2013/06/13 PHP
PHP执行shell脚本运行程序不产生core文件的方法
2016/12/28 PHP
使用PHP连接数据库_实现用户数据的增删改查的整体操作示例
2017/09/01 PHP
Javascript日期对象的dateAdd与dateDiff方法
2008/11/18 Javascript
javascript 获取HTML DOM父、子、临近节点
2014/06/16 Javascript
JavaScript动态修改弹出窗口大小的方法
2015/04/06 Javascript
php结合imgareaselect实现图片裁剪
2015/07/05 Javascript
JS组件Bootstrap Select2使用方法解析
2016/05/30 Javascript
javascript实现滚动效果的数字时钟实例
2016/07/21 Javascript
AngularJS 文件上传控件 ng-file-upload详解
2017/01/13 Javascript
JavaScript基础教程之如何实现一个简单的promise
2018/09/11 Javascript
JS实现纵向轮播图(初级版)
2020/01/18 Javascript
[00:43]DOTA2小紫本全民票选福利PA至宝全方位展示
2014/11/25 DOTA
在Python的Bottle框架中使用微信API的示例
2015/04/23 Python
python爬虫框架scrapy实战之爬取京东商城进阶篇
2017/04/24 Python
利用PyInstaller将python程序.py转为.exe的方法详解
2017/05/03 Python
Python线程同步的实现代码
2018/10/03 Python
Pycharm+Scrapy安装并且初始化项目的方法
2019/01/15 Python
Python中三元表达式的几种写法介绍
2019/03/04 Python
django中ORM模型常用的字段的使用方法
2019/03/05 Python
pytorch 模拟关系拟合——回归实例
2020/01/14 Python
HTML5-WebSocket实现聊天室示例
2016/12/15 HTML / CSS
英国的知名精品百货公司:House of Fraser(福来德)
2016/08/14 全球购物
香港交友网站:be2香港
2018/07/22 全球购物
马来西亚和新加坡巴士票在线预订:CatchThatBus
2018/11/17 全球购物
Linux不知道文件后缀名怎么判断文件类型
2012/04/26 面试题
编辑找工作求职信范文
2013/12/16 职场文书
城市轨道交通工程职业规划书范文
2014/01/18 职场文书
12月小学生校园广播稿
2014/02/04 职场文书
党员干部廉洁承诺书
2014/05/28 职场文书
建筑安全责任书范本
2014/07/24 职场文书
银行开户授权委托书格式
2014/10/10 职场文书
2015年扶贫帮困工作总结
2015/05/20 职场文书
公司行政管理制度范本
2015/08/05 职场文书
Python3 使用pip安装git并获取Yahoo金融数据的操作
2021/04/08 Python
Win11怎么添加用户?Win11添加用户账户的方法
2022/07/15 数码科技