位置: 编程技术 - 正文

MySQL慢查询之pt-query-digest分析慢查询日志(mysql的慢查询日志怎么查看)

发布时间:2024-02-26

推荐整理分享MySQL慢查询之pt-query-digest分析慢查询日志(mysql的慢查询日志怎么查看),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql 慢sql查询,mysql 慢查询,mysql order by desc 慢查询,mysql5.7慢查询,mysql5.7慢查询,mysql 慢查询,mysql 慢查询,mysql 慢查询,内容如对您有帮助,希望把文章链接给更多的朋友!

一、简介

pt-query-digest是用于分析mysql慢查询的一个工具,它可以分析binlog、General log、slowlog,也可以通过SHOWPROCESSLIST或者通过tcpdump抓取的MySQL协议数据来进行分析。可以把分析结果输出到文件中,分析过程是先对查询语句的条件进行参数化,然后对参数化以后的查询进行分组统计,统计出各查询的执行时间、次数、占比等,可以借助分析结果找出问题进行优化。

二、安装pt-query-digest

1.下载页面: pt-query-digest [OPTIONS] [FILES] [DSN] --create-review-table 当使用--review参数把分析结果输出到表中时,如果没有表就自动创建。 --create-history-table 当使用--history参数把分析结果输出到表中时,如果没有表就自动创建。 --filter 对输入的慢查询按指定的字符串进行匹配过滤后再进行分析 --limit 限制输出结果百分比或数量,默认值是,即将最慢的条语句输出,如果是%则按总响应时间占比从大到小排序,输出到总和达到%位置截止。 --host mysql服务器地址 --user mysql用户名 --password mysql用户密码 --history 将分析结果保存到表中,分析结果比较详细,下次再使用--history时,如果存在相同的语句,且查询所在的时间区间和历史表中的不同,则会记录到数据表中,可以通过查询同一CHECKSUM来比较某类型查询的历史变化。 --review 将分析结果保存到表中,这个分析只是对查询条件进行参数化,一个类型的查询一条记录,比较简单。当下次使用--review时,如果存在相同的语句分析,就不会记录到数据表中。 --output 分析结果输出类型,值可以是report(标准分析报告)、slowlog(Mysql slow log)、json、json-anon,一般使用report,以便于阅读。 --since 从什么时间开始分析,值为字符串,可以是指定的某个”yyyy-mm-dd [hh:mm:ss]”格式的时间点,也可以是简单的一个时间值:s(秒)、h(小时)、m(分钟)、d(天),如h就表示从小时前开始统计。 --until 截止时间,配合—since可以分析一段时间内的慢查询。

四、分析pt-query-digest输出结果

第一部分:总体统计结果

Overall:总共有多少条查询

Time range:查询执行的时间范围

unique:唯一查询数量,即对查询条件进行参数化以后,总共有多少个不同的查询

total:总计 min:最小 max:最大 avg:平均

%:把所有值从小到大排列,位置位于%的那个数,这个数一般最具有参考价值

median:中位数,把所有值从小到大排列,位置位于中间那个数

第二部分:查询分组统计结果

Rank:所有语句的排名,默认按查询时间降序排列,通过--order-by指定

Query ID:语句的ID,(去掉多余空格和文本字符,计算hash值)

Response:总的响应时间

time:该查询在本次分析中总的时间占比

calls:执行次数,即本次分析总共有多少条这种类型的查询语句

R/Call:平均每次执行的响应时间

MySQL慢查询之pt-query-digest分析慢查询日志(mysql的慢查询日志怎么查看)

V/M:响应时间Variance-to-mean的比率

Item:查询对象

第三部分:每一种查询的详细统计结果

由下面查询的详细统计结果,最上面的表格列出了执行次数、最大、最小、平均、%等各项目的统计。

ID:查询的ID号,和上图的Query ID对应

Databases:数据库名

Users:各个用户执行的次数(占比)

Query_time distribution :查询时间分布, 长短体现区间占比,本例中1s-s之间查询数量是s以上的两倍。

Tables:查询中涉及到的表

Explain:SQL语句

五、用法示例

1.直接分析慢查询文件:

2.分析最近小时内的查询:

3.分析指定时间范围内的查询:

4.分析指含有select语句的慢查询

5.针对某个用户的慢查询

6.查询所有所有的全表扫描或full join的慢查询

7.把查询保存到query_review表

8.把查询保存到query_history表

9.通过tcpdump抓取mysql的tcp协议数据,然后再分析

.分析binlog

.分析general log

总结

标签: mysql的慢查询日志怎么查看

本文链接地址:https://www.jiuchutong.com/biancheng/350070.html 转载请保留说明!

上一篇:MySQL慢查询之开启慢查询(mysql数据查询慢)

下一篇:win10下mysql 5.7.17 zip压缩包版安装教程

  • 个人卖给公司车需要什么手续
  • 人工费已经支付怎么入账
  • 劳务发票打款用途写什么
  • 农产品是零税率还是免税税率
  • 开票打印机可以自己买吗
  • 控股子公司增资扩股
  • 其他综合收益影响所有者权益吗
  • 进项认证勾选在哪里操作
  • 居民企业参股外国企业信息报告填写
  • 现金折扣的销售额
  • 单位起诉员工赔偿算劳动争议
  • 当月发货必须当月开票吗
  • 运费营改增时间
  • 入库前的挑选整理费用计入采购成本吗
  • 所有者权益的利得和损失
  • 实收资本印花税税率多少
  • 同一地级行政区指什么
  • 公司合作建房什么意思
  • 销售房地产要交培训费是传销行为吗
  • 企业筹建期发生的广告宣传费怎么抵减所得税
  • 进口增值税发票怎么认证
  • 社保显示已申报,但缴不了款
  • win10 20h2更新时间久
  • 怎么远程重装win10
  • .exe文件怎么打不开
  • 小企业会计准则下融资租入固定资产的核算
  • thinkphp d方法
  • 盒装cpu和散装
  • 玩游戏的显示器要高刷还是高分辨率
  • nuxt怎么用
  • win7打开启动
  • 坏账准备的会计科目
  • vue点击按钮显示对应的内容
  • Vue3中的pinia使用(收藏版)
  • 一分钟玩转钉钉文档是什么东西
  • 前端面试题必问的题目
  • lastlog日志
  • 短期借款的会计科目
  • java的基本
  • 小规模能取得专用发票吗
  • 应收预收的区别
  • ubuntu 14.04 安装分区教程
  • 《中华人民共和国治安管理处罚法》
  • 单位结余资金该如何处理
  • 饭店招牌发光字
  • 企业盘亏的原因怎么写
  • 复印件可以作为会计原始凭证吗
  • 利息为什么存在
  • 计提未发生的费用
  • 期末结转主营业务成本
  • 预付一年的房租怎么做账
  • 银行日记账上月的余额要结转吗
  • 销售方开红字发票需要什么信息
  • 财务负责人怎么实名认证
  • 房子贷款之后尾款发票
  • 房屋租赁账务如何做分录
  • 开红字发票需要具备什么条件
  • 工业企业生产什么
  • 酒店财务帐务处理方案
  • 史上最全的mysql基础教程
  • xp系统完全删除打印机驱动
  • ubuntu 无法正常启动
  • win8账户
  • win10 sp3
  • msoobe.exe是什么
  • linux安全性从何而来
  • suse linux教程
  • 如何永久激活win11
  • shell中的-le
  • 利用jQuery及AJAX技术定时更新GridView的某一列数据
  • Intermediate Unity 3D for iOS: Part 2/3
  • unity3d碰撞检测源码
  • 用nodejs实现三个类,动物基础类(有跑的函数,吃的函数)
  • 在python中的用法
  • 深入理解新发展理念,推进供给侧结构性改革
  • 安卓手机后退键
  • html折叠
  • 湖北省税务系统欠税管理工作指南
  • 怎么算税额和单位税额
  • 出口退税的企业货币要回国内吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号