千家信息网

MySQL慢日志分析工具pt-query-digest怎么用

发表于:2025-01-20 作者:千家信息网编辑
千家信息网最后更新 2025年01月20日,小编给大家分享一下MySQL慢日志分析工具pt-query-digest怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧
千家信息网最后更新 2025年01月20日MySQL慢日志分析工具pt-query-digest怎么用

小编给大家分享一下MySQL慢日志分析工具pt-query-digest怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

一、安装

去官网选择对应的版本和平台:



此处我用的是percona-toolkit-2.2.16.tar.gz,直接解压使用。

pt-query-digest [OPTION...] [FILE]
1、完整分析

  1. $ pt-query-digest slow_log > slow_report


2、分析最近1小时产生的日志\分析从--since到--until产生的日志

  1. $ pt-query-digest --since=1h slow_log > slow_report2


  2. $ pt-query-digest --since='2016-01-01 00:00:00' --until='2016-02-01' slow_log > slow_report3


3、针对某类语句分析,比如select

  1. $ pt-query-digest --filter '$event->{fingerprint} =~ m/^select/i' slow.log > slow_report4


4、针对某个用户分析,比如dbback

  1. $ pt-query-digest --filter '($event->{user} || "") =~ m/^dbback/i' slow.log> slow_report5


5、将分析结果输出到mysql-server中:

  1. $ pt-query-digest --review h=localhost,D=test,t=review slow.log


更多用法可参考官方手册



三、输出结果分析

第一部分:
Overall:
126.72k 被记录进来的查询次数,其中1k=10^3
140 去重之后的次数,即总共有多少个查询
Time range:
从日志中提取出2016-02-01 00:02:12 到 2016-03-02 03:02:30中的相关语句
接下来是时间和传输流量统计:
total:总计、min:最小值、max:最大值、avg:平均值、stddev:标准方差、median:中值



第二部分:
Rank:排序等级,在第三部分可以用于匹配具体语句
Query ID:16进制数的查询ID,在第三部分可以用于匹配具体语句
Response time:总共的响应时间,即这一条总共的执行时间
Calls:总共被查询的次数,即某一条总共被执行了多少层次
R/Calls:这一条的平均执行时间
V/M:方差均值比
Item:语句概览



第三部分:
Database:数据库名
Hosts:DB的host
Users:执行该语句的DB用户
Query_time distribution:该条语句执行时间的次数分布,###越多代表越多的执行时间在这个范围

其他:
如果要分析结果可视化,可以结合Anemometer等工具实现。

以上是"MySQL慢日志分析工具pt-query-digest怎么用"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!

0