SQL面试:如何快速定位消耗CPU最高的sql语句

46 篇文章 4 订阅
17 篇文章 1 订阅
如何快速定位消耗 CPU 最高的 sql 语句?看看下面的介绍。

概述

如果是Oracle数据库我们可以很容易通过sql来定位到当前数据库中哪些消耗CPU高的语句,而mysql数据库可以怎么定位呢?这里用一个简单例子说明下…

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

参考:

https://www.percona.com/blog/2020/04/23/a-simple-approach-to-troubleshooting-high-cpu-in-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 <mysqld_pid> 1  5  

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

sql面试题,数据库面试题目,定位sql语句,如何找到消耗CPU最高的sql语句,查看问题sql执行计划 根据操作系统id可以到processlist表找到对应的会话,如下:

 sql面试题,数据库面试题目,定位sql语句,如何找到消耗CPU最高的sql语句,查看问题sql执行计划

查看问题sql执行计划

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

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

 sql面试题,数据库面试题目,定位sql语句,如何找到消耗CPU最高的sql语句,查看问题sql执行计划

了解更多数据库知识,点击原文链接:www.shulanxt.com/doc/mysqldoc/sqlmsd

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值