略微加速

略速 - 互联网笔记

Mysql占用CPU过高排查过程及可能优化方案

2022-11-11 leiting (1847阅读)

标签 MySql

1.查看生产DB服务器top列表,


执行 top 命令


2.使用root用户登录mysql


执行 show full processlist 查看慢查询,反复执行,如果发现一直有select 查询语句存在,为了缓解DB服务器压力,直接使用kill命令杀掉


kill 慢查询的id


如果服务器压力缓解,恢复正常。


3.查询是否有锁问题


show OPEN TABLES where In_use > 0;


查看正在锁的事务


SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS;


查看等待锁的事务


SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCK_WAITS;


4.杀掉当前所有的MySQL连接


mysqladmin -uroot -p processlist|awk -F "|" '{print $2}' |xargs -n 1 mysqladmin -uroot -p kill


Mysql占用CPU过高如何优化


1.打开慢查询日志,查询是否是某个SQL语句占用过多资源,如果是的话,可以对SQL语句进行优化,比如优化 insert 语句、优化 group by 语句、优化 order by 语句、优化 join 语句等等;

2.考虑索引问题,使用explain关键字分析SQL

3.定期分析表,使用optimize table;

4.优化数据库对象;

5.考虑是否是锁问题;

6.调整一些MySQL Server参数,比如key_buffer_size、table_cache、innodb_buffer_pool_size、innodb_log_file_size等等;

7.如果数据量过大,可以考虑使用MySQL集群或者搭建高可用环境。


北京半月雨文化科技有限公司.版权所有 京ICP备12026184号-3