mysql show profile详解_慢查询分析调优工具~show profile

继上一篇mysqldumpslow工具的讲解,今天来聊聊show profile。也是MySQL服务自带的分析调优工具,不过这款更高级,比较接近底层硬件参数的调优。

3458b0670feadc880219ff746366795f.png

查看show profile设置

show variables like 'profiling%';//默认关闭,保存近15次的运行结果

9284a97e17225a421d464a96d572881b.png

开启

set profiling = on;

c2c43fa74e0fab004b385a768d21ac43.png

查看最近15次的运行结果

show profiles;

备注:

show warnings;//可以显示警告和报错的信息

ae12b15f3b365cebfe670cef55f0806c.png

诊断运行的SQL

命令:show profile cpu,block io for query query_id;

例子:

show profile cpu,block io for query 3;

通过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 //彻底清理

79cb61dcc5edc3a008f04c43095292b5.png

Type:

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 //出现死锁

通过查询数据表来诊断SQL(第二种查询方式)

select * from information_schema.profiling;

56a38d32b0a5ae298ad79291a86dff5b.png

全局查询日志(第二种SQL诊断方式)

此方式诊断较简单(参数少,适合定位有问题的SQL),记录到数据库(建议只在测试库环境进行)

设置

方式1:命令行

1. set global general_log = 1;

2. set global log_output = 'TABLE';

方式2:配置文件

* vim my.cnf

general_log =1

general_log_file = /path/logfile

log_output = FILE

* 重启MySQL服务

诊断SQL

select * from mysql.general_log;

825689ea1ba19e96314954ee554f1fef.png

本作品采用《CC 协议》,转载必须注明作者和本文链接

阿德

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值