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

推荐(免费):mysql教程(视频)
继上一篇mysqldumpslow工具的讲解,今天来聊聊show profile。也是MySQL服务自带的分析调优工具,不过这款更高级,比较接近底层硬件参数的调优。

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

开启
set profiling = on;

查看最近15次的运行结果
show profiles;备注:show warnings;//可以显示警告和报错的信息

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

蓝心千询
蓝心千询是vivo推出的一个多功能AI智能助手
34 查看详情
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;

全局查询日志(第二种SQL诊断方式)
此方式诊断较简单(参数少,适合定位有问题的SQL),记录到数据库(建议只在测试库环境进行)
设置
方式1:命令行1. set global general_log = 1;2. set global log_output = 'TABLE';
方式2:配置文件* vim my.cnfgeneral_log =1general_log_file = /path/logfilelog_output = FILE* 重启MySQL服务
诊断SQL
select * from mysql.general_log;

以上就是mysql的慢查询分析调优工具 show profile的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/293418.html
微信扫一扫
支付宝扫一扫