首頁 > 資料庫 > mysql教程 > mysql的慢查詢分析調優工具 show profile

mysql的慢查詢分析調優工具 show profile

coldplay.xixi
發布: 2020-12-29 09:25:33
轉載
1927 人瀏覽過

mysql教學#介紹慢查詢分析調優工具

mysql的慢查詢分析調優工具 show profile

推薦(免費):mysql教學(影片)

繼上一篇mysqldumpslow工具的解說,今天來聊聊show profile。也是MySQL服務自帶的分析調優工具,不過這款比較高級,比較接近底層硬體參數的調優。

慢查询分析调优工具~show profile

檢視show profile設定

#
show variables like 'profiling%';//默认关闭,保存近15次的运行结果
登入後複製

慢查询分析调优工具~show profile

開始

慢查询分析调优工具~show profile

慢查询分析调优工具~show profile

慢查询分析调优工具~show profile

慢查询分析调优工具~show profile

慢查询分析调优工具~show profile

##################################################### ####
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的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:learnku.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板