找文章 / 找答案
精选问答 更多内容

[SQL独家资料] 快速定位数据库消耗 CPU 最高的 SQL语句

喝酸奶不舔盖青铜四 显示全部楼层 发表于 2024-5-30 16:50:03 |阅读模式 打印 上一主题 下一主题
如何快速定位消耗 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  
企业微信截图_57cf5a3c-71b5-41f1-981c-eb4844b39d64.png

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

定位问题sql
企业微信截图_3046e2a0-32e1-4888-a411-b83a49f86c8d.png
select * from performance_schema.threads where thread_os_id = xx ;  
select * from information_schema.`PROCESSLIST` where  id=threads.processlist_id  


根据操作系统id可以到processlist表找到对应的会话,如下:
企业微信截图_ba02418f-8c10-477e-87cc-29e778eceb5d.png

查看问题sql执行计划

这里对应看一下执行计划基本就可以判断当前数据库CPU为什么消耗这么高了...
至于优化的点只需要在dock建一个索引即可,这里就不介绍了。
企业微信截图_bf8059f9-3015-46dd-820f-8bc684903bae.png

文章源自:公众号:SQL数据库开发

回复

使用道具 举报

高级模式
您需要登录后才可以回帖 登录 | 免费注册

  • 官方微信

    欢迎关注永洪服务号!收费为0,价值无限

    扫码关注
  • 新浪微博

    让每位用户轻松挖掘数据价值!

    访问新浪微博
  • 智能客服
50W

会员等你来哦

Copyright   ©2012-2024  北京永洪商智科技有限公司  (京ICP备12050607) 京公网安备110110802011451号 |《永洪社区协议》
返回顶部