0

0

mysqlcpu占用过高怎么办_性能瓶颈分析

P粉602998670

P粉602998670

发布时间:2025-12-24 12:11:44

|

274人浏览过

|

来源于php中文网

原创

MySQL CPU过高需先区分外部压力或内部低效:系统层确认mysqld进程CPU占比,定位高耗线程并关联SQL;再通过QPS与CPU曲线对比判断是流量激增还是慢查询主导;最后用processlist、慢日志或Performance Schema定位问题SQL,并依执行计划优化索引、排序、临时表及连接管理。

mysqlcpu占用过高怎么办_性能瓶颈分析

MySQL CPU 占用过高,核心不是“压测一下再调”,而是快速区分是外部压力驱动还是内部执行低效。先看现象,再查根源,最后动手优化——跳过这三步,盲目调参或加索引反而可能让问题更隐蔽。

确认是不是 mysqld 真正在吃 CPU

别一上来就进数据库。先在系统层确认:

  • 运行 tophtop,按 P(按 CPU 排序),找到 mysqld 进程;如果它长期 >80%,继续往下查
  • 运行 ps -mp -o THREAD,tid,time | sort -rn,看哪个线程(TID)占 CPU 最多
  • 把高耗 TID 转成十六进制:printf "%x\n" ,后续可结合 SHOW PROCESSLISTperformance_schema.threads 关联 SQL

区分是 QPS 激增还是慢查询主导

CPU 高 ≠ SQL 写得差,也可能是流量真的太大:

Smodin AI Content Detector
Smodin AI Content Detector

多语种AI内容检测工具

下载
  • 查当前 QPS:SHOW GLOBAL STATUS LIKE 'Questions';SHOW GLOBAL STATUS LIKE 'Uptime';,算出平均每秒查询数
  • 对比历史曲线:如果 CPU 曲线和 QPS 曲线高度同步上升,大概率是并发请求太多,需从应用层限流、加缓存(如 Redis)、或读写分离入手
  • 如果 CPU 飙高但 QPS 平稳甚至偏低,重点盯慢查询、锁等待、临时表、排序操作——这类问题往往一条 SQL 就能拖垮整实例

定位高消耗 SQL 的三种实用方式

不用等慢日志满,现场就能抓到“真凶”:

  • show full processlist:直接看 State 列,重点关注 Sending data(数据传输中)、Copying to tmp table(建临时表)、Sorting result(排序)、Locked(锁住)的语句;Info 列显示不全时,用 SELECT * FROM information_schema.PROCESSLIST WHERE INFO IS NOT NULL
  • 启用并检查 slow_query_log:在 my.cnf 中设 slow_query_log = 1long_query_time = 1(单位秒),重启后分析日志;注意:即使 long_query_time = 0 也能记录所有查询,适合紧急排查
  • 用 Performance Schema 实时追踪:开启相关消费者,例如:UPDATE performance_schema.setup_consumers SET ENABLED = 'YES' WHERE NAME LIKE '%statements%';,然后查 performance_schema.events_statements_summary_by_digest,按 TOTAL_LATENCYEXEC_COUNT 排序找“高频+高耗时”语句

常见瓶颈点与对应优化动作

找到 SQL 后,别急着改代码。先看执行计划,再定策略:

  • 全表扫描(type=ALL):explain 显示没走索引?检查 where 条件字段是否缺失索引,或存在隐式类型转换(如 varchar 字段传数字)、函数包裹(WHERE DATE(create_time) = '2025-12-20'
  • Using filesort / Using temporary:order by 或 group by 没走索引?尝试为排序字段加联合索引,或减少 select *,只取必要字段
  • 大量临时表:检查 tmp_table_sizemax_heap_table_size 是否过小;临时表转磁盘会极大拉高 CPU,适当调大(但别超过物理内存 20%)
  • 连接数爆炸SHOW STATUS LIKE 'Threads_connected'; 如果接近 max_connections,说明连接没释放,要查应用是否漏关连接,或启用连接池(如 HikariCP)
  • InnoDB 锁竞争:运行 SHOW ENGINE INNODB STATUS\G,看 TRANSACTIONSLOCK WAIT 部分;长事务、未提交更新、gap lock 都可能引发连锁等待

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

673

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

319

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

344

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1080

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

355

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

670

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

561

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

404

2024.04.29

苹果官网入口直接访问
苹果官网入口直接访问

苹果官网直接访问入口是https://www.apple.com/cn/,该页面具备0.8秒首屏渲染、HTTP/3与Brotli加速、WebP+AVIF双格式图片、免登录浏览全参数等特性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

10

2025.12.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.4万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 769人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号