帮助中心/最新通知

质量为本、客户为根、勇于拼搏、务实创新

< 返回文章列表

【服务器相关】MySQL常用慢查询分析工具详解

发表时间:2025-06-16 03:46:00 小编:主机乐-Yutio

引言

在日常的业务开发中
MySQL 出现慢查询是很常见的

大部分情况下会分为两种情况:

  • 1、业务增长太快
  • 2、要么就是SQL 写的太xx了

所以
对慢查询 SQL 进行分析和优化很重要
其中 mysqldumpslow 是 MySQL 服务自带的一款很好的分析调优工具

1、调优工具mysqldumpslow

1.1调优工具常用设置

1、什么是MySQL 慢查询日志

MySQL提供的一种慢查询日志记录,用来记录在MySQL查询中响应时间超过阀值的记录 具体指运行时间超过long_query_time值的SQL,则会被记录到慢查询日志中

2、如何查看慢查询设置情况

慢查询的时间阈值设置

【性能优化】MySQL常用慢查询分析工具_数据库

解释:

  • slow_query_log //是否开启,默认关闭,建议调优时才开启
  • slow_query_log_file //慢查询日志存放路径

3、如何开启慢查询日志记录

1) 命令开启

【性能优化】MySQL常用慢查询分析工具_mysql_02

默认值是10秒

4)如何设置查询阀值

命令设置

【性能优化】MySQL常用慢查询分析工具_数据库_03

配置文件设置:

【性能优化】MySQL常用慢查询分析工具_数据库_04

5)如何把未使用索引的 SQL 记录写入慢查询日志

【性能优化】MySQL常用慢查询分析工具_mysql_05

开启配置:

【性能优化】MySQL常用慢查询分析工具_数据库_06

6)模拟数据

【性能优化】MySQL常用慢查询分析工具_数据库_07

1.2 调优工具常用命令

语法格式

【性能优化】MySQL常用慢查询分析工具_数据库_08

通过上面我们发现,show profile工具默认是关闭状态,15表示保存了近15次的运行结果。

2、开启调优工具

执行下面的命令开启

【性能优化】MySQL常用慢查询分析工具_数据库_09

3、查看最近15次的运行结果

【性能优化】MySQL常用慢查询分析工具_数据库_10

4、诊断运行的SQL

接下来,我们一起诊断一下query id为23的慢查询

【性能优化】MySQL常用慢查询分析工具_数据库_11

 解释:通过Status一列,可以看到整条SQL的运行过程

  • 1. starting //开始
  • 2. checking permissions //检查权限
  • 3. Opening tables //打开数据表
  • 4. init //初始化
  • 5. System lock //锁机制
  • 6. optimizing //优化器
  • 7. statistics //分析语法树
  • 8. prepareing //预准备
  • 9. executing //引擎执行开始
  • 10. end //引擎执行结束
  • 11. query end //查询结束
  • 12. closing tables //释放数据表
  • 13. freeing items //释放内存
  • 14. cleaning up //彻底清理

查看类型选项
SHOW PROFILE…后面的列,即:SHOW PROFILE ALL, BLOCK IO, … FOR QUERY 209;
ALL //显示索引的开销信息
BLOCK IO //显示块IO相关开销
CONTEXT SWITCHES//上下文切换相关开销
CPU //显示CPU相关开销信息
IPC //显示发送和接收相关开销信息
MEMORY //显示内存相关开销信息
PAGE FAULTS //显示页面错误相关开销信息
SOURCE //显示和source_function,source_file,source_line相关的开销信息
SWAPS //显示交换次数相关开销的信息

重要提示:


如出现以下一种或者几种情况,说明SQL执行性能极其低下,亟需优化
* converting HEAP to MyISAM//查询结果太大,内存都不够用了往磁盘上搬了
* Creating tmp table //创建临时表:拷贝数据到临时表,用完再删
* Copying to tmp table on disk //把内存中临时表复制到磁盘,危险
* locked //出现死锁

到此这篇关于MySQL常用慢查询分析工具详解的文章就介绍到这了,更多相关MySQL慢查询工具内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!


联系我们
返回顶部