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

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

概述

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

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

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

主要意思是针对定位CPU的问题,Percona增长了对经过信息的TID列将processlist ID映射到OS线程ID的支持,而MySQL在5.7版本后在PERFORMANCE\_SCHEMA.THREADS表加了一个THREAD\_OS\_ID新列来实现,如下方法适用于在其余内核正常运行时,某个特定CPU的查询过载的状况。app

find out which session is using the most CPU resources in my database?优化

定位线程

pidstat -t -p <mysqld_pid> 1  5

图片

经过该命令咱们能够定位到80二、4445等线程消耗了大量的CPU,这里尽可能确保在pidstat的多个样本中验证消耗是恒定的。根据这些信息,咱们能够登陆到数据库,并使用如下查询找出哪一个MySQL线程是罪魁祸首。spa

定位问题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建一个索引便可,这里就不介绍了。3d

图片

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

相关文章
相关标签/搜索