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

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

查看show profile设置

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

开启

setprofiling=on;

查看最近15次的运行结果

showprofiles;备注:showwarnings;//可以显示警告和报错的信息

诊断运行的SQL

命令:showprofilecpu,blockioforqueryquery_id;例子:showprofilecpu,blockioforquery3;通过Status一列,可以看到整条SQL的运行过程1.starting//开始2.checkingpermissions//检查权限3.Openingtables//打开数据表4.init//初始化5.Systemlock//锁机制6.optimizing//优化器7.statistics//分析语法树8.prepareing//预准备9.executing//引擎执行开始10.end//引擎执行结束11.queryend//查询结束......12.closingtables//释放数据表13.freeingitems//释放内存14.cleaningup//彻底清理

Type:ALL//显示索引的开销信息BLOCKIO//显示块IO相关开销CONTEXTSWITCHES//上下文切换相关开销CPU//显示CPU相关开销信息IPC//显示发送和接收相关开销信息MEMORY//显示内存相关开销信息PAGEFAULTS//显示页面错误相关开销信息SOURCE//显示和source_function,source_file,source_line相关的开销信息SWAPS//显示交换次数相关开销的信息

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

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

select*frominformation_schema.profiling;

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

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

设置

方式1:命令行1.setglobalgeneral_log=1;2.setgloballog_output='TABLE';

方式2:配置文件*vimmy.cnfgeneral_log=1general_log_file=/path/logfilelog_output=FILE*重启MySQL服务

诊断SQL

select*frommysql.general_log;

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