当前位置:主页 > 查看内容

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

发布时间:2021-05-11 00:00| 位朋友查看

简介:如何快速定位消耗 CPU 最高的? sql 语句,怎么做?看看下面的介绍。 概述 如果是Oracle数据库我们可以很容易通过 sql 来定位到当前数据库中哪些消耗CPU高的语句,而mysql数据库可以怎么定位呢?这里用一个简单例子说明下... 主要是了解如何定位的思路,具体……

如何快速定位消耗 CPU 最高的?sql 语句,怎么做?看看下面的介绍。

概述

如果是Oracle数据库我们可以很容易通过sql来定位到当前数据库中哪些消耗CPU高的语句,而mysql数据库可以怎么定位呢?这里用一个简单例子说明下...

主要是了解如何定位的思路,具体看官网介绍..

参考:https://www.percona.com/blog/...

主要意思是针对定位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/i6923...


本文转自网络,版权归原作者所有,原文链接:https://segmentfault.com/a/1190000039979168
本站部分内容转载于网络,版权归原作者所有,转载之目的在于传播更多优秀技术内容,如有侵权请联系QQ/微信:153890879删除,谢谢!
上一篇:CTO 写的代码,真是绝了! 下一篇:没有了

推荐图文


随机推荐