快速定位当前数据库消耗 CPU 最高的 sql 语句
如何快速定位消耗 CPU 最高的 sql 语句,怎么做?看看下面的介绍。
概述
如果是Oracle数据库我们可以很容易通过sql来定位到当前数据库中哪些消耗CPU高的语句,而mysql数据库可以怎么定位呢
如何快速定位消耗 CPU 最高的 sql 语句,怎么做?看看下面的介绍。 概述 如果是Oracle数据库我们可以很容易通过sql来定位到当前数据库中哪些消耗CPU高的语句,而mysql数据库可以怎么定位呢?这里用一个简单例子说明下... 主要是了解如何定位的思路mssql 语句快速参考,具体看官网介绍.. 参考: 主要意思是针对定位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? 定位线程
图片 通过该命令我们可以定位到**「802、4445等线程消耗了大量的CPU」**,这里尽量确保在pidstat的多个样本中验证消耗是恒定的。根据这些信息,我们可以登录到数据库,并使用以下查询找出哪个MySQL线程是罪魁祸首。 定位问题sql
图片 根据操作系统id可以到processlist表找到对应的会话,如下: 图片查看问题sql执行计划 这里对应看一下执行计划基本就可以判断当前数据库CPU为什么消耗这么高了... 至于优化的点只需要在dock建一个索引即可,这里就不介绍了。 (编辑:晋中站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |