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

沙海 2021年6月14日09:47:33Java评论17字数 1699阅读5分39秒阅读模式
摘要

智能摘要

智能摘要文章源自JAVA秀-https://www.javaxiu.com/32327.html

点击上方"Java基基",选择"设为星标"做积极的人,而不是积极废人!这里尽量确保在pidstat的多个样本中验证消耗是恒定的。根据这些信息,我们可以登录到数据库,并使用以下查询找出哪个MySQL线程是罪魁祸首。至于优化的点只需要在dock建一个索引即可,这里就不介绍了。欢迎加入我的知识星球,一起探讨架构,交流源码。文章源自JAVA秀-https://www.javaxiu.com/32327.html

原文约 2839 | 图片 10 | 建议阅读 6 分钟 | 评价反馈文章源自JAVA秀-https://www.javaxiu.com/32327.html

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

点击关注 ? Java基基 文章源自JAVA秀-https://www.javaxiu.com/32327.html

收录于话题文章源自JAVA秀-https://www.javaxiu.com/32327.html

#Java基基文章源自JAVA秀-https://www.javaxiu.com/32327.html

156个文章源自JAVA秀-https://www.javaxiu.com/32327.html

点击上方“Java基基”,选择“设为星标”文章源自JAVA秀-https://www.javaxiu.com/32327.html

做积极的人,而不是积极废人!文章源自JAVA秀-https://www.javaxiu.com/32327.html

文章源自JAVA秀-https://www.javaxiu.com/32327.html

源码精品专栏文章源自JAVA秀-https://www.javaxiu.com/32327.html

 文章源自JAVA秀-https://www.javaxiu.com/32327.html

文章源自JAVA秀-https://www.javaxiu.com/32327.html

来源:toutiao.com/i6923526305795293707文章源自JAVA秀-https://www.javaxiu.com/32327.html

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

概述

如果是Oracle数据库我们可以很容易通过sql来定位到当前数据库中哪些消耗CPU高的语句,而mysql数据库可以怎么定位呢?这里用一个简单例子说明下...文章源自JAVA秀-https://www.javaxiu.com/32327.html

主要是了解如何定位的思路,具体看官网介绍..文章源自JAVA秀-https://www.javaxiu.com/32327.html

参考:文章源自JAVA秀-https://www.javaxiu.com/32327.html

https://www.percona.com/blog/2020/04/23/a-simple-approach-to-troubleshooting-high-cpu-in-mysql/文章源自JAVA秀-https://www.javaxiu.com/32327.html

主要意思是针对定位CPU的问题,Percona增加了对通过信息的TID列将processlist ID映射到OS线程ID的支持,而MySQL在5.7版本后在PERFORMANCE_SCHEMA.THREADS表加了一个THREAD_OS_ID新列来实现,以下方法适用于在其他内核正常运行时,某个特定CPU的查询过载的情况。文章源自JAVA秀-https://www.javaxiu.com/32327.html

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

定位线程

pidstat -t -p <mysqld_pid> 1  5

快速定位当前数据库消耗 CPU 最高的 sql 语句文章源自JAVA秀-https://www.javaxiu.com/32327.html

通过该命令我们可以定位到**「802、4445等线程消耗了大量的CPU」** ,这里尽量确保在pidstat的多个样本中验证消耗是恒定的。根据这些信息,我们可以登录到数据库,并使用以下查询找出哪个MySQL线程是罪魁祸首。文章源自JAVA秀-https://www.javaxiu.com/32327.html

定位问题sql

select * from performance_schema.threads where thread_os_id = xx ;select * from information_schema.`PROCESSLIST` where  id=threads.processlist_id

快速定位当前数据库消耗 CPU 最高的 sql 语句文章源自JAVA秀-https://www.javaxiu.com/32327.html

根据操作系统id可以到processlist表找到对应的会话,如下:文章源自JAVA秀-https://www.javaxiu.com/32327.html

快速定位当前数据库消耗 CPU 最高的 sql 语句文章源自JAVA秀-https://www.javaxiu.com/32327.html

查看问题sql执行计划

这里对应看一下执行计划基本就可以判断当前数据库CPU为什么消耗这么高了...文章源自JAVA秀-https://www.javaxiu.com/32327.html

至于优化的点只需要在dock建一个索引即可,这里就不介绍了。文章源自JAVA秀-https://www.javaxiu.com/32327.html

快速定位当前数据库消耗 CPU 最高的 sql 语句文章源自JAVA秀-https://www.javaxiu.com/32327.html

- END -文章源自JAVA秀-https://www.javaxiu.com/32327.html

文章源自JAVA秀-https://www.javaxiu.com/32327.html

欢迎加入我的知识星球,一起探讨架构,交流源码。加入方式,长按下方二维码噢文章源自JAVA秀-https://www.javaxiu.com/32327.html

快速定位当前数据库消耗 CPU 最高的 sql 语句文章源自JAVA秀-https://www.javaxiu.com/32327.html

已在知识星球更新源码解析如下:文章源自JAVA秀-https://www.javaxiu.com/32327.html

快速定位当前数据库消耗 CPU 最高的 sql 语句文章源自JAVA秀-https://www.javaxiu.com/32327.html

快速定位当前数据库消耗 CPU 最高的 sql 语句文章源自JAVA秀-https://www.javaxiu.com/32327.html

快速定位当前数据库消耗 CPU 最高的 sql 语句文章源自JAVA秀-https://www.javaxiu.com/32327.html

快速定位当前数据库消耗 CPU 最高的 sql 语句文章源自JAVA秀-https://www.javaxiu.com/32327.html

最近更新《芋道 SpringBoot 2.X 入门》系列,已经 20 余篇,覆盖了 MyBatis、Redis、MongoDB、ES、分库分表、读写分离、SpringMVC、Webflux、权限、WebSocket、Dubbo、RabbitMQ、RocketMQ、Kafka、性能测试等等内容。文章源自JAVA秀-https://www.javaxiu.com/32327.html

提供近 3W 行代码的 SpringBoot 示例,以及超 4W 行代码的电商微服务项目。文章源自JAVA秀-https://www.javaxiu.com/32327.html

获取方式:点“在看”,关注公众号并回复 666 领取,更多内容陆续奉上。文章源自JAVA秀-https://www.javaxiu.com/32327.html

文章源自JAVA秀-https://www.javaxiu.com/32327.html

文章有帮助的话,在看,转发吧。谢谢支持哟 (*^__^*)
文章源自JAVA秀-https://www.javaxiu.com/32327.html

阅读原文文章源自JAVA秀-https://www.javaxiu.com/32327.html

继续阅读
速蛙云 - 极致体验,强烈推荐!!!购买套餐就免费送各大视频网站会员!快速稳定、独家福利社、流媒体稳定解锁!速度快,全球上网、视频、游戏加速、独立IP均支持!基础套餐性价比很高!这里不多说,我一直正在使用,推荐购买:https://www.javaxiu.com/59919.html
weinxin
资源分享QQ群
本站是JAVA秀团队的技术分享社区, 会经常分享资源和教程; 分享的时代, 请别再沉默!
沙海
匿名

发表评论

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定