mysql 中的 slow log 是用来记录执行时间较长(超过 long_query_time 秒)的 sql 的一种日志工具。

启用 slow log

在 my.cnf 中设置

[mysqld]

slow_query_log=on

slow_query_log_file=mysql-slow

重启 MySQL 服务。

五款常用工具

mysqldumpslow

mysqlsla

myprofi

mysql-explain-slow-log

mysql-log-filter

mysqldumpslow

mysql官方提供的慢查询日志分析工具。输出图表如下:

主要功能包括统计不同慢 sql 的

出现次数(Count)

执行耗费的平均时间和累计总耗费时间(Time)

等待锁耗费的时间(Lock)

发送给客户端的行总数(Rows)

扫描的行总数(Rows)

用户以及sql语句本身(抽象了一下格式,比如 limit 1, 20 用 limit N,N 表示)

mysqlsla

hackmysql.com 推出的一款日志分析工具(该网站还维护了 mysqlreport,mysqlidxchk 等比较实用的mysql 工具)。

整体来说,功能非常强大。输出的数据报表非常有利于分析慢查询的原因,包括执行频率、数据量、查询消耗等。

格式说明如下:

总查询次数 (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

http://www.bt285.cn/content.php?id=1196863

功能上有点瑕疵。不仅把所有的 slow log 打印到屏幕上,而且统计也只有数量而已,不推荐使用。

mysql-log-filter

google code 上找到的一个分析工具,提供了 python 和 php 两种可执行的脚本。

http://code.google.com/p/mysql-log-filter/

功能上比官方的 mysqldumpslow 多了查询时间的统计信息(平均、最大、累计),其他功能都与 mysqldumpslow 类似。

特色功能除了统计信息外,还针对输出内容做了排版和格式化,保证整体输出的简洁。喜欢简洁报表的朋友,推荐使用一下。

myprofi

纯 php 写的一个开源分析工具.项目在 sourceforge 上。

http://myprofi.sourceforge.net/

功能上,列出了总的慢查询次数和类型、去重后的 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

非常精简

mysql slow log 分析工具_mysql slow log分析工具的比较相关推荐

  1. mysql慢查询日志轮转_MySQL slow log相关参数解释

    slow_query_log=1       #是否启用慢查询日志,1为启用,0为禁用 slow_query_log_file=slow.log       #指定慢查询日志文件的路径和名字,可使用绝 ...

  2. mysql 8.0 慢查询_MySQL慢查询分析

    [伍哥原创] 在我们做系统性能调优的时候,数据库的慢查询语句的优化是必不可少的,特别是电子商务类型的重度MYSQL应用类型. 下面我们一起来看看怎么做好MYSQL的慢查询分析吧. 1,开启MYSQL的 ...

  3. mysql 高可用工具_MySQL Utilities 高可用工具体验

    MySQL Utilities 高可用工具体验 MySQL Utilities是MySQL官方的工具集,其中包括高可用相关的几个工具. 以下是对当前最新版本1.6的使用体验. 前提条件 MySQL S ...

  4. mysql for 语句执行顺序_MySQL使用profile分析SQL语句执行过程

    分析SQL执行带来的开销是优化SQL的重要手段.在MySQL数据库中,可以通过配置profiling参数来启用SQL剖析.该参数可以在全局和session级别来设置.对于全局级别则作用于整个MySQL ...

  5. mysql 数据库日志管理工具_mysql mysqlbinlog日志管理工具使用教程

    一.概述 由于服务器生成的二进制日志文件以二进制格式保存,所以如果要想检查这些文件的文本格式,就会用到mysqlbinlog日志管理工具. mysqlbinlog的语法如下: mysqlbinlog ...

  6. mysql 联合主键 加锁_MySQL 加锁处理分析

    背景 MySQL/InnoDB的加锁分析,一直是一个比较困难的话题.我在工作过程中,经常会有同事咨询这方面的问题.同时,微博上也经常会收到MySQL锁相关的私信,让我帮助解决一些死锁的问题.本文,准备 ...

  7. 常用mysql连接数据库工具_MYSQL中常用的工具

    1.mysql(客户端链接工具): -u :指定用户名 -p:指定密码 -h:指定服务器ip或者域名 -P(大写):指定端口 例子:mysql -u root -h 202.194.132.237 - ...

  8. mysql宕机日志查询_mysql宕机分析(事务日志损坏)

    mysql宕机分析(事务日志损坏) 一.情景概述. 1.服务器配置 a)  1CPU 8核 b)  16G内存 c)  2T 硬盘 2. Mysql 在一个普通硬盘中长时间处于大量写的状态(长时间大概 ...

  9. mysql 结构对比工具_Mysql 数据库结构 对比工具

    一. This program does not update a database. It only produces update scripts (which show the differen ...

最新文章

  1. Tesla超越谷歌无人驾驶汽车雄心的背后,是以色列公司Mobileye
  2. 【干货】Oracle数据库常用十一大操作指令
  3. 使用Qt的多线程编程
  4. maven工程拆分与聚合的思想
  5. python to sql_python的to_sql那点儿事
  6. elementui 如何修改表格里面cell的样式
  7. 微信上线红包新玩法,今年春节可以“当面”给红包了!
  8. 怎么生成a类型的对象 java_Java工程师考试题(答案)
  9. 第二十单元 计划任务crond服务
  10. python-基于UDP通信的套接字,socketserver模块的使用
  11. JDBC连接池原理及分析
  12. HTML前端代码分析(查看网站黑链的几种方法)暗链是什么意思
  13. iOS p12证书获取
  14. oracle授权怎么收费,Oracle数据库如何授权收费(Database Licensing)
  15. 公开我的 星际帝国 辅助程序源代码
  16. Laragon 自定义域名
  17. serviceBattery mac换电池 mac怎么换电池mac拆机
  18. 干货 : 揭秘信息可视化图表的设计方法
  19. 骑马与砍杀2从原神抓取武器模型到导入进游戏使用
  20. 代码强力对比,就用这7个工具!

热门文章

  1. ApiController得到服务器端绝对路径
  2. spring-data-mongodb查询结果返回指定字段
  3. 设计模式——简单工厂
  4. 数据冗余的理解和相关概念
  5. 小问题,对递归重复调用的改进,一起来分享
  6. Linux关闭防火墙详述
  7. Linux文件夹权限如何更改?
  8. 9个提高代码运行效率的小技巧你知道几个?
  9. 你会选择深圳还是佛山?
  10. 程序的内存分配模式(堆栈以及静态存储区,文字常量区,代码区)