mysql的慢查询剖析调优工具 show profile
发布时间:01/01 来源:未知 浏览:
关键词:
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 //彻底清算
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.cnf general_log =1 general_log_file = /path/logfile log_output = FILE * 重新启动MySQL效劳
诊断SQL
select * from mysql.general_log;
以上就是mysql的慢查询剖析调优工具 show profile的具体内容,更多请关注百分百源码网其它相关文章!