mysql怎样快速定位当前比较耗费cpu的sql

通过top和top-H命令检查CPU使用情况,关注特定pid。接着在MySQL数据库中利用performance_schema.threads和events_statements_current表来查询对应线程的SQL执行情况,从而定位高CPU使用的问题源头。
摘要由CSDN通过智能技术生成

先使用top命令查看cpu整体使用情况:

再使用top -H查看线程cpu使用情况:

#记录下pid,然后进数据库里查询下其对应的sql:

1.查看线程信息

SELECT * FROM performance_schema.threads WHERE thread_os_id IN('1604', '1560', '1561','1568');

--黄色阴影部分id是上面的pid

可以看到是哪个ip的哪个用户,在执行哪个sql:

--这里一次展示不全,分两次截的图。

2.查看events_statements_current中更详细信息

SELECT *

FROM

  performance_schema.`events_statements_current`

WHERE thread_id IN

  (SELECT thread_id

  FROM performance_schema.threads

  WHERE thread_os_id IN ('1604', '1560', '1561','1568')) ;

--本篇文章转自:

MySQL CPU很高,如何排查 – 小麦苗DBA宝典

并做了些许改动。

小麦苗上写的文章非常好,感谢!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值