mysql的慢查询分析调优工具show profile怎么用
这篇文章主要介绍了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怎么用”这篇文章对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,更多相关知识等着你来学习!
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。