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

 更新时间:2024年01月14日 16:06:53   作者:风暴飘絮  
这篇文章主要介绍了MySQL占用CPU过高排查过程及可能优化方案,具有很好的参考价值,希望对大家的学习或工作有所帮助,感兴趣的朋友可以参考下

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集群或者搭建高可用环境。

以上就是MySQL占用CPU过高排查过程及可能优化方案的详细内容,更多关于MySQL占用CPU过高的资料请关注脚本之家其它相关文章!

相关文章

  • 浅谈MySQL中的子查询优化技巧

    浅谈MySQL中的子查询优化技巧

    这篇文章主要介绍了浅谈MySQL中的子查询优化技巧,子查询的优化是MySQL诸多优化方法中的基本,需要的朋友可以参考下
    2015-05-05
  • Windows下简单的Mysql备份BAT脚本分享

    Windows下简单的Mysql备份BAT脚本分享

    朋友说在windows下面用bat命令备份失败,他一时找不到问题所在,于是找我帮忙查看下。查找后解决了该问题,想着总结下来,所以这篇文章主要跟大家分享了一个在Windows下简单的Mysql备份BAT脚本,需要的朋友可以参考下。
    2017-03-03
  • MySQL 慢日志相关知识总结

    MySQL 慢日志相关知识总结

    慢日志在日常数据库运维中经常会用到,我们可以通过查看慢日志来获得效率较差的 SQL ,然后可以进行 SQL 优化。本篇文章我们一起来学习下慢日志相关知识。
    2021-05-05
  • 教你如何在 MySQL 数据库中支持完整的Unicode

    教你如何在 MySQL 数据库中支持完整的Unicode

    UTF-8 是一种可变宽度编码,它使用一到四个 8 位字节对每个符号进行编码,永远不要在MySQL中使用 utf8——总是使用 utf8mb4,对mysql支持 Unicode相关知识感兴趣的朋友一起看看吧
    2023-01-01
  • 使用MySQL的yum源安装MySQL5.7数据库的方法

    使用MySQL的yum源安装MySQL5.7数据库的方法

    这篇文章主要介绍了使用MySQL的yum源安装MySQL5.7数据库的方法的相关资料,需要的朋友可以参考下
    2016-08-08
  • mysql 卡死 大部分线程长时间处于sending data的状态

    mysql 卡死 大部分线程长时间处于sending data的状态

    首先说明一下,这是个无头的案子,虽然问题貌似解决了,不过到现在我也没有答案,只是把这个问题拿出来晾晾
    2008-11-11
  • 找回MySQL管理员root密码的3个妙招

    找回MySQL管理员root密码的3个妙招

    最近笔者的一台mysql服务器忘记了超级管理员root密码,而mysql修改密码必须得知道旧密码的情况下才能进行,真的很郁闷,找了很多方法都无 效,最终找到了解决方法,下面把mysql root密码找回妙招分享给大家,感兴趣的朋友一起看看吧
    2022-11-11
  • 5个MySQL GUI工具推荐,帮助你进行数据库管理

    5个MySQL GUI工具推荐,帮助你进行数据库管理

    这篇文章主要介绍了5个MySQL GUI工具推荐,帮助大家更好的进行MySQL数据库管理,感兴趣的朋友可以了解下
    2020-08-08
  • MySQL中主键默认有索引吗

    MySQL中主键默认有索引吗

    MySQL主键默认是有索引的,在MySQL中,主键是用来唯一标识表中每一行数据的字段或字段组合,主键的作用是保证数据的唯一性,并且可以提高数据的查询效率,需要的朋友可以参考下
    2023-10-10
  • 关于SQL嵌套的误解分析

    关于SQL嵌套的误解分析

    之前我曾一直以为:就是在sql语句嵌套时,嵌套查询的约束和外层的约束是没有关系的。
    2010-12-12

最新评论