您现在的位置是:首页 > 技术教程 正文

如何快速定位当前数据库消耗 CPU 最高的sql 语句?

暂无作者 阅读: 2024-01-04
后台-插件-广告管理-内容页头部广告(手机)
如何快速定位消耗 CPU 最高的 sql 语句,怎么做?看看下面的介绍。
概述
如果是Oracle数据库我们可以很容易通过sql来定位到当前数据库中哪些消耗CPU高的语句,而mysql数据库可以怎么定位呢?
这里用一个简单例子说明下…
主要是了解如何定位的思路,具体看官网介绍..
参考:https://www.percona.com/blog/2020/04/23/a-simple-approach-to-troubleshooting-high-cpu-in-mysql/
主要意思是针对定位CPU的问题,Percona增加了对通过信息的TID列将processlist ID映射到OS线程ID的支持,而MySQL在5.7版本后在PERFORMANCE_SCHEMA.THREADS表加了一个THREAD_OS_ID新列来实现.
以下方法适用于在其他内核正常运行时,某个特定CPU的查询过载的情况。

 
find out which session is using the most CPU resources in my database?
 
定位线程

 
pidstat -t -p <mysqld_pid> 1  5
 
图片
 
通过该命令我们可以定位到802、4445等线程消耗了大量的CPU,这里尽量确保在pidstat的多个样本中验证消耗是恒定的。
根据这些信息,我们可以登录到数据库,并使用以下查询找出哪个MySQL线程是罪魁祸首。
定位问题sql

 
select * from performance_schema.threads where thread_os_id = xx ;
select * from information_schema.`PROCESSLIST` where  id=threads.processlist_id
 
 
图片
 
根据操作系统id可以到processlist表找到对应的会话,如下:
 
图片
查看问题sql执行计划
这里对应看一下执行计划基本就可以判断当前数据库CPU为什么消耗这么高了…
至于优化的点只需要在dock建一个索引即可,这里就不介绍了。
图片
标签:
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

在线投稿:投稿 站长QQ:1888636

后台-插件-广告管理-内容页尾部广告(手机)
关注我们

扫一扫关注我们,了解最新精彩内容

搜索