mysql的慢查询分析调优工具 show profile


本文摘自PHP中文网,作者coldplay.xixi,侵删。

mysql教程介绍慢查询分析调优工具

推荐(免费):mysql教程(视频)

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

慢查询分析调优工具~show profile

查看show profile设置

1

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

慢查询分析调优工具~show profile

开启

1

set profiling = on;

慢查询分析调优工具~show profile

查看最近15次的运行结果

1

2

3

show profiles;

备注:

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

慢查询分析调优工具~show profile

诊断运行的SQL

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

命令: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 //彻底清理

慢查询分析调优工具~show profile

1

2

3

4

5

6

7

8

9

10

Type:

ALL //显示索引的开销信息

BLOCK IO //显示块IO相关开销

CONTEXT SWITCHES  //上下文切换相关开销

CPU //显示CPU相关开销信息

IPC //显示发送和接收相关开销信息

MEMORY //显示内存相关开销信息

PAGE FAULTS //显示页面错误相关开销信息

SOURCE //显示和source_function,source_file,source_line相关的开销信息

SWAPS //显示交换次数相关开销的信息

1

2

3

4

5

如出现以下一种或者几种情况,说明SQL执行性能极其低下,亟需优化

* converting HEAP to MyISAM  //查询结果太大,内存都不够用了往磁盘上搬了

* Creating tmp table //创建临时表:拷贝数据到临时表,用完再删

* Copying to tmp table on disk //把内存中临时表复制到磁盘,危险

* locked //出现死锁

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

1

select * from information_schema.profiling;

慢查询分析调优工具~show profile

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

1

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

设置

1

2

3

方式1:命令行

1. set global general_log = 1;

2. set global log_output = 'TABLE';

1

2

3

4

5

6

方式2:配置文件

* vim my.cnf

general_log =1

general_log_file = /path/logfile

log_output = FILE

* 重启MySQL服务

诊断SQL

1

select * from mysql.general_log;

慢查询分析调优工具~show profile

以上就是mysql的慢查询分析调优工具 show profile的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

mysql数据库配置信息查看与修改方法详解

怎么用mysql打开数据库

mysql中如何实现按照特定顺序排序

分布式事务的图文详解

安装最新版本mysql导致登录phpmyadmin报错

mysql5.7单实例自启动服务配置过程

mysql 存储过程详解

mysql事务管理的介绍(附示例)

什么是脏读?

pk主键是什么意思?

更多相关阅读请进入《mysql》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...