mysql数据库cpu飙升800%,基本上就两种原因:
访问量大,大到你8核cpu都承受不了;
慢查询,数据库执行sql语句操作(查询数据、修改数据)会产生大量的逻辑读,将读出来的数据维护到临时表中(内存),系统需要消耗较多的cpu来维持内存与磁盘数据的一致性。
大多数情况下都是开发人员对sql的把握质量不够,导致慢sql查询的产生,进而影响数据库的整体运行状况。
大量行锁冲突、行锁等待或后台任务也有可能会导致实例的 CPU 使用率过高,但这些情况出现的概率非常低。当我们的数据库性能下降的厉害或者cpu飙升时候,可以进行如下操作定位问题:
查询mysql进程列表show full processlist; 获取到mysql当前使用的进程:
如果进程很多,说明请求量很大,需要区分是否正常业务流量,还是代码问题导致的。
查询慢查询日志show variables like '%slow_query_log%';
找到慢查询日志文件/home/mysql/data3085/mysql/slow_query.