加入收藏 | 设为首页 | 会员中心 | 我要投稿 源码网 (https://www.900php.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

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

发布时间:2023-01-10 15:01:19 所属栏目:MsSql教程 来源:转载
导读:

原文链接:
这篇文章主要介绍怎么快速定位当前数据库消耗CPU最高的sql语句,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
如何快速定位消耗 CPU 最高的 sql 语

快速反射镜模型参考自适应控制器_mssql_mssql 语句快速参考

mssql_mssql 语句快速参考_快速反射镜模型参考自适应控制器

原文链接:

这篇文章主要介绍怎么快速定位当前数据库消耗CPU最高的sql语句,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

如何快速定位消耗 CPU 最高的 sql 语句,怎么做?

概述

如果是Oracle数据库我们可以很容易通过sql来定位到当前数据库中哪些消耗CPU高的语句,而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 1 5

快速反射镜模型参考自适应控制器_mssql_mssql 语句快速参考

通过该命令我们可以定位到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

mssql 语句快速参考_快速反射镜模型参考自适应控制器_mssql

mssql_mssql 语句快速参考_快速反射镜模型参考自适应控制器

查看问题sql执行计划

这里对应看一下执行计划基本就可以判断当前数据库CPU为什么消耗这么高了...

至于优化的点只需要在dock建一个索引即可,这里就不介绍了。

mssql_快速反射镜模型参考自适应控制器_mssql 语句快速参考

以上是“怎么快速定位当前数据库消耗CPU最高的sql语句”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识mssql 语句快速参考,欢迎关注亿速云行业资讯频道!

(编辑:源码网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!