MySQL Slow Log慢日志分析(一)
来源:互联网 发布:8月m2数据 编辑:程序博客网 时间:2024/06/01 09:58
MySQL Slow Log慢日志分析(一)
2010-01-5 | 20:32分类:MySQL | 标签:slow log | 11,393 views
医生给病人诊断的时候,一般会使用听诊器来诊断肺部是否正常。如果你的MySQL出现了性能问题,第一个需要“诊断”的就是slow log(慢日志)了。
slow log文件很小,使用more less等命令就足够了。如果slow log很大怎么办?这里介绍MySQL自带的工具mysqldumpslow来帮你解析慢日志(也可以跳过本文,直接阅读Manual)。
1. 基本使用
$mysqldumpslow slow.log > slow.dat
$more slow.dat
$more slow.dat
输出的数据:
Count: 3 Time=62.67s (188s) Lock=0.00s (0s) Rows=1623770.7 (4871312), root[root]@localhost
SELECT /*!N SQL_NO_CACHE */ * FROM `feed_receive_0287`
SELECT /*!N SQL_NO_CACHE */ * FROM `feed_receive_0287`
这里我们能够获得:这条语句在满日志中的出现次数、平均执行时间、总共执行时间、row send等。例如:SELECT /*!N SQL_NO_CACHE */ * FROM `feed_receive_0287`一共执行了3次,平均每次使用62秒。
在默认情况下,mysqlslowdump的输出结果会使用N和S代替SQL中出现的数字和字符串。例如:如下慢日志
SELECT COUNT(*) as counter FROM feed_receive f WHERE f.RATED_UID=21621 AND f.suspended=-1 AND f.rater_type=4 AND f.rate=-2 AND f.username="orczhou.com"
会被mysqlslowdump抽象为:
SELECT COUNT(*) as counter FROM feed_receive f WHERE f.RATED_UID=N AND f.suspended=-N AND f.rater_type=N AND f.rate=-N AND f.username="S"
如果想禁用这种抽象,可以使用-a参数
2. 排序参数
mysqlslowdump默认输出结果是按照count(SQL出现的次数)排序的。可以通过如下的参数控制:
-s t按总query time排序-s at按平均query time排序-s l按总locktime排序-s al按平均lock time排序-s s按总row send排序-s as按平均row send排序-s c按count排序----例如:
mysqldumpslow -s at slow.log.old > slow.2.dat #按照平均query time排序查看日志
3. 其他参数
-r倒着排序-a不要将数字和字符串抽象成N和S-g仅仅分析相匹配的query4. 常用命令
由上面的常用参数就可以组合出如下的常用命令:
mysqldumpslow -s t slow.log.old > slow.1.dat #按照query time排序查看日志
mysqldumpslow -s at slow.log.old > slow.2.dat #按照平均query time排序查看日志
mysqldumpslow -a -s at slow.log.old > slow.3.dat #按照平均query time排序并且不抽象数字的方式排序
mysqldumpslow -a -s c slow.log.old > slow.4.dat #安装执行次数排序
mysqldumpslow -s at slow.log.old > slow.2.dat #按照平均query time排序查看日志
mysqldumpslow -a -s at slow.log.old > slow.3.dat #按照平均query time排序并且不抽象数字的方式排序
mysqldumpslow -a -s c slow.log.old > slow.4.dat #安装执行次数排序
- MySQL Slow Log慢日志分析(一)
- mysql慢日志 :slow query log 分析数据
- shell脚本分析mysql慢查询日志(slow log)
- mysql慢日志 :slow query log 分析数据
- mysql 5.5 开启慢日志slow log
- MySQL 慢查询日志(Slow Query Log)
- MySQL 慢查询日志(Slow Query Log)
- MySQL 慢查询日志(Slow Query Log)
- 使用pt-query-digest分析mysql慢查询日志(mysql slow query log )
- MySQL 日志之--慢查询日志(slow-query-log)
- MySQL日志(一):slow query log
- MySQL中的慢查询日志(Slow Query Log)
- [MySQL Slow log]正确安全清空在线慢查询日志slow log的流程
- [MySQL Slow log]正确安全清空在线慢查询日志slow log的流程
- mysql5.5 慢日志slow log
- 分析slow-log 每小时慢sql情况
- MySQL错误日志(error log),二进制日志(binlog),慢查询日志(slow query log),查询日志(general log),重写日志(redo log)
- 善用php-fpm的慢执行日志slow log分析PHP执行效率和程序BUG
- linux下用aptitude管理软件包
- C# 反射实现步骤
- 并行计算模型
- VC 2010+MFC:CMFCToolBar和CMFCMenuBar的字体大小修改
- Uboot与Linux之间的参数传递
- MySQL Slow Log慢日志分析(一)
- 五、与事件一起工作
- .net中防止SQL注入 方法
- html外部js文件引用其他js文件的函数
- C++标准库
- mysql的myisam存储引擎特性(三)
- Netty 源码分析
- 获取iOS的设备型号
- 汉字串排序