如何疾速定位耗费 CPU 最高的 sql 语句,怎么做?看看上面的介绍。
概述
如果是Oracle数据库咱们能够很容易通过sql来定位到以后数据库中哪些耗费CPU高的语句,而mysql数据库能够怎么定位呢?这里用一个简略例子阐明下...
次要是理解如何定位的思路,具体看官网介绍..
参考:https://www.percona.com/blog/...
次要意思是针对定位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
依据操作系统id能够到processlist表找到对应的会话,如下:
查看问题sql执行打算
这里对应看一下执行打算根本就能够判断以后数据库CPU为什么耗费这么高了...
至于优化的点只须要在dock建一个索引即可,这里就不介绍了。
原文:https://www.toutiao.com/i6923...