智能摘要文章源自JAVA秀-https://www.javaxiu.com/37447.html
通过该命令我们可以定位到**「802、4445等线程消耗了大量的CPU」**,这里尽量确保在pidstat的多个样本中验证消耗是恒定的。根据这些信息,我们可以登录到数据库,并使用以下查询找出哪个MySQL线程是罪魁祸首。文章源自JAVA秀-https://www.javaxiu.com/37447.html
原文约 1017 字 | 图片 7 张 | 建议阅读 3 分钟 | 评价反馈文章源自JAVA秀-https://www.javaxiu.com/37447.html
快速定位当前数据库消耗 CPU 最高的 sql 语句
小哈学Java 文章源自JAVA秀-https://www.javaxiu.com/37447.html
文章源自JAVA秀-https://www.javaxiu.com/37447.html
如何快速定位消耗 CPU 最高的 sql 语句,怎么做?看看下面的介绍。文章源自JAVA秀-https://www.javaxiu.com/37447.html
概述
如果是Oracle数据库我们可以很容易通过sql来定位到当前数据库中哪些消耗CPU高的语句,而mysql数据库可以怎么定位呢?这里用一个简单例子说明下...文章源自JAVA秀-https://www.javaxiu.com/37447.html
主要是了解如何定位的思路,具体看官网介绍..文章源自JAVA秀-https://www.javaxiu.com/37447.html
参考:文章源自JAVA秀-https://www.javaxiu.com/37447.html
https://www.percona.com/blog/2020/04/23/a-simple-approach-to-troubleshooting-high-cpu-in-mysql/文章源自JAVA秀-https://www.javaxiu.com/37447.html
主要意思是针对定位CPU的问题,Percona增加了对通过信息的TID列将processlist ID映射到OS线程ID的支持,而MySQL在5.7版本后在PERFORMANCE_SCHEMA.THREADS
表加了一个THREAD_OS_ID
新列来实现,以下方法适用于在其他内核正常运行时,某个特定CPU的查询过载的情况。文章源自JAVA秀-https://www.javaxiu.com/37447.html
find out which session is using the most CPU resources in my database?
文章源自JAVA秀-https://www.javaxiu.com/37447.html
定位线程
pidstat -t -p <mysqld_pid> 1 5
文章源自JAVA秀-https://www.javaxiu.com/37447.html
图片文章源自JAVA秀-https://www.javaxiu.com/37447.html
通过该命令我们可以定位到**「802、4445等线程消耗了大量的CPU」**,这里尽量确保在pidstat的多个样本中验证消耗是恒定的。根据这些信息,我们可以登录到数据库,并使用以下查询找出哪个MySQL线程是罪魁祸首。文章源自JAVA秀-https://www.javaxiu.com/37447.html
定位问题sql
select * from performance_schema.threads where thread_os_id = xx ; select * from information_schema.`PROCESSLIST` where id=threads.processlist_id
文章源自JAVA秀-https://www.javaxiu.com/37447.html
图片文章源自JAVA秀-https://www.javaxiu.com/37447.html
根据操作系统id可以到processlist表找到对应的会话,如下:文章源自JAVA秀-https://www.javaxiu.com/37447.html
文章源自JAVA秀-https://www.javaxiu.com/37447.html
图片文章源自JAVA秀-https://www.javaxiu.com/37447.html
查看问题sql执行计划
这里对应看一下执行计划基本就可以判断当前数据库CPU为什么消耗这么高了...文章源自JAVA秀-https://www.javaxiu.com/37447.html
至于优化的点只需要在dock建一个索引即可,这里就不介绍了。文章源自JAVA秀-https://www.javaxiu.com/37447.html
文章源自JAVA秀-https://www.javaxiu.com/37447.html
图片文章源自JAVA秀-https://www.javaxiu.com/37447.html
(感谢阅读,希望对你所有帮助)文章源自JAVA秀-https://www.javaxiu.com/37447.html
来源:www.toutiao.com/i6923526305795293707文章源自JAVA秀-https://www.javaxiu.com/37447.html
1. 还在用Jenkins?看看这些替代方案,是否更适合你!2. Sharding-Jdbc实现读写分离、分库分表,妙!3. Springboot中如何优雅的进行字段校验4. 如何让Spring Boot 的配置 “动” 起来?最近面试BAT,整理一份面试资料《Java面试BATJ通关手册》,覆盖了Java核心技术、JVM、Java并发、SSM、微服务、数据库、数据结构等等。获取方式:点“在看”,关注公众号并回复 Java 领取,更多内容陆续奉上。
文章有帮助的话,在看,转发吧。文章源自JAVA秀-https://www.javaxiu.com/37447.html
谢谢支持哟 (*^__^*)文章源自JAVA秀-https://www.javaxiu.com/37447.html

评论