点击上方“码农突围”,马上关注
这里是码农充电第一站,回复“666”,获取一份专属大礼包
真爱,请设置“星标”或点个“在看

如何快速定位消耗 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建一个索引即可,这里就不介绍了。

(感谢阅读,希望对你所有帮助)
来源:www.toutiao.com/i6923526305795293707
- END -
最近热文• 做技术的,要做到什么水平,才能年薪百万?• 程序员被公司辞退12天,前领导要求回公司讲清楚代码,结果懵了• 外包干三年,必废!• 哈哈哈哈,16 岁高中生开发「粤语编程」项目,在 GitHub 火了!
本文介绍了在MySQL数据库中定位高CPU消耗SQL语句的方法。通过使用Percona工具和MySQL 5.7以后的PERFORMANCE_SCHEMA.THREADS表,可以将线程PID与OS线程ID关联,从而找出问题线程。通过pidstat命令监控CPU使用,再结合performance_schema.threads和information_schema.PROCESSLIST查询,能识别出占用CPU最多的会话和相应的SQL语句。掌握这种方法有助于排查和优化数据库性能。
794

被折叠的 条评论
为什么被折叠?



