用户在使用 MySQL 实例时,会遇到 CPU 使用率过高甚至达到 100% 的情况。本文将介绍造成该状况的常见原因以及解决方法,并通过 CPU 使用率为 100% 的典型场景,来分析引起该状况的原因及其相应的解决方案。
常见原因
系统执行应用提交查询(包括数据修改操作)时需要大量的逻辑读(逻辑 IO,执行查询所需访问的表的数据行数),所以系统需要消耗大量的 CPU 资源以维护从存储系统读取到内存中的数据一致性。
说明:大量行锁冲突、行锁等待或后台任务也有可能会导致实例的 CPU 使用率过高,但这些情况出现的概率非常低,本文不做讨论。
一、定位问题SQL
数据库CPU超频,首要原因分析为执行SQL导致,先定位正在执行的SQL
# 进入数据库连接工具,或者MySQL命令客户端
# 查询正在执行的SQL
select * from information_schema.`PROCESSLIST` where info is not null;
根据COMMAND、TIME、STATE、INFO三个字段查询SQL信息
COMMAND – 执行的数据操作类型
TIME – 执行的时间
STATE – 执行的状态
INFO – 执行的具体SQL
发现很长一段时间,查询都处在 “Sending data”状态
查询一下“Sending data”状态的含