这篇文章主要介绍怎么快速定位当前数据库消耗CPU最高的sql语句,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
如何快速定位消耗 CPU 最高的 sql 语句,怎么做?
概述
如果是Oracle数据库我们可以很容易通过sql来定位到当前数据库中哪些消耗CPU高的语句,而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
通过该命令我们可以定位到802、4445等线程消耗了大量的CPU,这里尽量确保在pidstat的多个样本中验证消耗是恒定的。根据这些信息,我们可以登录到数据库,并使用以下查询找出哪个MySQL线程是罪魁祸首。
定位问题sql
select*fromperformance_schema.threadswherethread_os_id=xx;select*frominformation_schema.`PROCESSLIST`whereid=threads.processlist_id
查看问题sql执行计划
这里对应看一下执行计划基本就可以判断当前数据库CPU为什么消耗这么高了...
至于优化的点只需要在dock建一个索引即可,这里就不介绍了。
-
cpu
+关注
关注
68文章
10824浏览量
211094 -
SQL
+关注
关注
1文章
759浏览量
44060 -
数据库
+关注
关注
7文章
3759浏览量
64266 -
MySQL
+关注
关注
1文章
801浏览量
26435 -
线程
+关注
关注
0文章
504浏览量
19646
原文标题:教你如何快速定位当前数据库消耗 CPU 最高的 sql 语句
文章出处:【微信号:良许Linux,微信公众号:良许Linux】欢迎添加关注!文章转载请注明出处。
发布评论请先 登录
相关推荐
评论