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

发布时间:2020-12-29 14:40:06 作者:小新
来源:亿速云 阅读:305

这篇文章主要介绍了mysql的慢查询分析调优工具show profile怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

show profile也是MySQL服务自带的分析调优工具,不过这款更高级,比较接近底层硬件参数的调优。

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

查看show profile设置

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

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

开启

set profiling = on;

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

查看最近15次的运行结果

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

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

诊断运行的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 //彻底清理

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

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;

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

全局查询日志(第二种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;

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

感谢你能够认真阅读完这篇文章,希望小编分享的“mysql的慢查询分析调优工具show profile怎么用”这篇文章对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,更多相关知识等着你来学习!

推荐阅读:
  1. MySQL性能分析、及调优工具使用详解
  2. MySql中show profile的用法

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

mysql show profile

上一篇:explode与split在php中有什么不同

下一篇:怎么在Linux环境中安装CoreSeek

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》