五款常用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 相关文章推荐
建立文件交换功能的脚本(一)
Oct 09 PHP
php学习之数据类型之间的转换介绍
Jun 09 PHP
PHP图片验证码制作实现分享(全)
May 10 PHP
基于curl数据采集之单页面并行采集函数get_htmls的使用
Apr 28 PHP
php实现简单洗牌算法
Jun 18 PHP
PHP动态规划解决0-1背包问题实例分析
Mar 23 PHP
PHP中把数据库查询结果输出为json格式简单实例
Apr 09 PHP
php使用file函数、fseek函数读取大文件效率对比分析
Nov 04 PHP
php自定义截取中文字符串-utf8版
Feb 27 PHP
基于Codeigniter框架实现的student信息系统站点动态发布功能详解
Mar 23 PHP
php实现的双色球算法示例
Jun 20 PHP
多个Laravel项目如何共用migrations详解
Sep 25 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
vBulletin Forum 2.3.xx SQL Injection
2006/10/09 PHP
PHP+javascript模拟Matrix画面
2006/10/09 PHP
浅谈使用 Yii2 AssetBundle 中 $publishOptions 的正确姿势
2017/11/08 PHP
JS实现图片预加载无需等待
2012/12/21 Javascript
JS中Iframe之间传值的方法
2013/03/11 Javascript
js中switch case循环实例代码
2013/12/30 Javascript
display和visibility的区别示例介绍
2014/02/26 Javascript
BootStrap的弹出框(Popover)支持鼠标移到弹出层上弹窗层不隐藏的原因及解决办法
2016/04/03 Javascript
JSON 对象未定义错误的解决方法
2016/09/29 Javascript
在vue项目中引入highcharts图表的方法(详解)
2018/03/05 Javascript
Vue自定义属性实例分析
2019/02/23 Javascript
小程序scroll-view安卓机隐藏横向滚动条的实现详解
2019/05/16 Javascript
vue前后分离调起微信支付
2019/07/29 Javascript
详解elementui之el-image-viewer(图片查看器)
2019/08/30 Javascript
Postman内建变量常用方法实例解析
2020/07/28 Javascript
仅用50行代码实现一个Python编写的计算器的教程
2015/04/17 Python
python中列表和元组的区别
2017/12/18 Python
python爬虫的数据库连接问题【推荐】
2018/06/25 Python
解决python3 urllib 链接中有中文的问题
2018/07/16 Python
python高级特性和高阶函数及使用详解
2018/10/17 Python
对python中的six.moves模块的下载函数urlretrieve详解
2018/12/19 Python
把vgg-face.mat权重迁移到pytorch模型示例
2019/12/27 Python
Python调用钉钉自定义机器人的实现
2020/01/03 Python
python标准库OS模块函数列表与实例全解
2020/03/10 Python
5行Python代码实现图像分割的步骤详解
2020/05/25 Python
Pytorch转tflite方式
2020/05/25 Python
详解Tensorflow不同版本要求与CUDA及CUDNN版本对应关系
2020/08/04 Python
python 元组和列表的区别
2020/12/30 Python
一篇文章教你用python画动态爱心表白
2020/11/22 Python
BookOutlet加拿大:在网上书店购买廉价折扣图书和小说
2018/10/05 全球购物
事业单位个人应聘自荐信
2013/09/21 职场文书
应届大专毕业生自我鉴定
2014/04/08 职场文书
我们的节日国庆活动方案
2014/08/19 职场文书
教师工作失职检讨书
2014/09/18 职场文书
教育教学读书笔记
2015/07/02 职场文书
如何通过简单的代码描述Angular父组件、子组件传值
2022/04/07 Javascript