查看原文
其他

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

点击关注👉 民工哥技术之路 2021-12-16

点击下方公众号「关注」和「星标」

回复“1024”获取独家整理的学习资料!

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

原文:https://www.toutiao.com/i6923526305795293707/

推荐阅读 点击标题可跳转

我卖掉北京 500 万的房子,在老家生活的这两年…

最牛逼的性能监控系统!集强大功能于一身

不错哦!通过 Nginx 来实现封杀恶意访问

CentOS 之父创造的 Rocky Linux 8.3 发布!附下载

卧槽!Docker 将 “ 跳过更新 ” 设为付费功能

成都最最最牛逼的 IT 公司全在这了

超牛逼!100 个开箱即用的 Shell 脚本,拿好了~

从0到1!etcd 服务入门指南

大佬用 Redis 实现一个轻量级的搜索引擎,牛x啊 !

: . Video Mini Program Like ,轻点两下取消赞 Wow ,轻点两下取消在看

您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存