mysql的cpu使用率100%问题排查

背景

线上mysql服务器经常性出现cpu使用率100%的告警, 因此整理一下排查该问题的常规流程。


1. 确认CPU占用来源

  • 检查系统进程
    使用 tophtop 命令,确认是否是 mysqld 进程导致CPU满载:
    top -c -p $(pgrep mysqld)
    

2. 实时分析MySQL活动

  • 查看当前运行的SQL
    登录MySQL,执行以下命令,观察是否有长时间运行或高频率的查询:
    SHOW FULL PROCESSLIST;
    -- 或过滤非空闲连接
    SELECT * FROM INFORMATION_SCHEMA.PROCESSLIST 
    WHERE COMMAND != 'Sleep' AND TIME > 0;
    

  • 终止问题查询
    若发现异常查询,可通过 KILL [PROCESS_ID] 终止。

3. 分析慢查询与执行计划

  • 启用慢查询日志
    在MySQL配置文件(my.cnf/my.ini)中启用慢查询日志:

    slow_query_log = 1
    slow_query_log_file = /var/log/mysql/slow.log
    long_query_time = 2  -- 阈值(秒)
    

    重启MySQL后,使用 mysqldumpslowpt-query-digest 分析日志。

  • 使用 EXPLAIN 分析SQL
    对可疑查询添加 EXPLAIN,检查是否缺少索引或全表扫描:

    EXPLAIN SELECT * FROM your_table WHERE your_condition;
    

4. 检查索引与表结构

  • 索引缺失
    通过 SHOW CREATE TABLE 检查表结构,确保高频查询字段有索引。
  • 冗余索引
    使用 pt-duplicate-key-checker 工具删除无效索引。
  • 统计信息过时
    执行 ANALYZE TABLE your_table; 更新统计信息。

5. 排查锁争用与事务

  • 查看当前锁状态
    SHOW ENGINE INNODB STATUS;  -- 查看LATEST DETECTED DEADLOCK
    SELECT * FROM INFORMATION_SCHEMA.INNODB_TRX;  -- 运行中的事务
    SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS;  -- 当前持有的锁
    
  • 长事务处理
    终止未提交的长事务或优化事务代码。

6. 检查MySQL配置

  • 关键参数调优
    • innodb_buffer_pool_size:建议设置为物理内存的70%-80%。
    • max_connections:避免过高导致资源争用。
    • tmp_table_sizemax_heap_table_size:减少磁盘临时表。
  • 连接数监控
    SHOW STATUS LIKE 'Threads_connected';  -- 当前连接数
    SHOW VARIABLES LIKE 'max_connections';  -- 最大允许连接数
    

7. 系统资源与硬件瓶颈

  • 内存与交换分区
    使用 free -hvmstat 检查内存是否不足,导致频繁Swap。
  • 磁盘I/O
    使用 iostatiotop 查看磁盘负载,优化高I/O操作(如批量写入、索引重建)。
  • CPU架构
    确认是否因并发线程过多导致CPU争用(如 innodb_thread_concurrency 设置)。

8. 其他可能原因

  • 复制问题
    主从复制延迟或错误可能导致从库CPU升高,检查 SHOW SLAVE STATUS
  • 缓存失效
    如查询缓存(query_cache_type)频繁失效,考虑关闭。
  • 日志写入压力
    关闭不必要的日志(如通用查询日志),或调整 sync_binlog 参数。

9. 使用专业工具

  • 监控工具
    Percona Monitoring and Management (PMM)、VividCortex 或 Prometheus + Grafana。
  • 性能分析工具
    pt-query-digestmysqlsla 或 MySQL自带的 Performance Schema

快速处理步骤

  1. top 确认MySQL进程导致CPU满载。
  2. SHOW PROCESSLIST 查找异常查询。
  3. EXPLAIN 分析问题SQL,优化索引或查询逻辑。
  4. 终止阻塞进程(KILL)或重启MySQL(临时恢复)。

通过以上步骤,多数情况下可以定位到CPU过高的根本原因,如慢查询、索引缺失、配置不当或硬件瓶颈,进而针对性优化。若问题复杂,建议结合监控工具长期跟踪分析。

最后

欢迎点击关注gzh: 加瓦点灯,不错过每一次的干货!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/894875.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用jmeter进行压力测试

使用jmeter进行压力测试 jmeter安装 官网安装包下载,选择二进制文件,解压。 tar -xzvf apache-jmeter-x.tgz依赖jdk安装。 yum install java-1.8.0-openjdk环境变量配置,修改/etc/profile文件,添加以下内容。 export JMETER/…

【蓝桥杯嵌入式】6_定时器输入捕获

全部代码网盘自取 链接:https://pan.baidu.com/s/1PX2NCQxnADxYBQx5CsOgPA?pwd3ii2 提取码:3ii2 这是两个信号发生器,可以通过调节板上的两个电位器R39和R40调节输出频率。 将PB4、PA15选择ch1,两个信号发生器只能选择TIM3和TIM…

详解SQLAlchemy的函数relationship

在 SQLAlchemy 中,relationship 是一个非常重要的函数,用于定义模型之间的关系。它用于在 ORM 层面上表示数据库表之间的关联关系(如 1 对 1、1 对多和多对多)。relationship 的主要作用是提供一个高级接口,用于在模型…

iOS 音频录制、播放与格式转换

iOS 音频录制、播放与格式转换:基于 AVFoundation 和 FFmpegKit 的实现 在 iOS 开发中,音频处理是一个非常常见的需求,比如录音、播放音频、音频格式转换等。本文将详细解读一段基于 AVFoundation 和 FFmpegKit 的代码,展示如何实现音频录制、播放以及 PCM 和 AAC 格式之间…

数据结构与算法(test1)

一、树和二叉树 1. 看图,完成以下填空 (1).树的度为________。 (2).树中结点的最大层次,称为树的_____或树的______,值是______。 (3).结点A和B的度分别为________ 和 ________。 (4).结点A是结点B的________。 (5).结点B是结点A的________…

新版AndroidStudio 修改 jdk版本

一、问题 之前,在安卓项目中配置JDK和Gradle的过程非常直观,只需要进入Android Studio的File菜单中的Project Structure即可进行设置,十分方便。 如下图可以在这修改JDK: 但是升级AndroidStudio之后,比如我升级到了Android Stu…

cursor 开发java项目教程简单上手

1.官网下载 Cursor - The AI Code Editor 下载完后注册账号,可以使用无限邮的方式 注册完之后 设置中文 可以选择设置为中文 Ctrl Shift X 进入设置页面输入chinese 然后重启 更改jdk跟maven仓库设置 ctrlshiftp 打开输入框后输入json,把下面代码…

安装和使用 Ollama(实验环境windows)

下载安装 下载 https://ollama.com/download/windows 安装 Windows 安装 如果直接双击 OllamaSetup.exe 安装,默认会安装到 C 盘,如果需要指定安装目录,需要通过命令行指定安装地址,如下: # 切换到安装目录 C:\Use…

LQB(0)-python-基础知识

一、Python开发环境与基础知识 python解释器:用于解释python代码 方式: 1.直接安装python解释器 2.安装Anaconda管理python环境 python开发环境:用于编写python代码 1.vscode 2.pycharm # 3.安装Anaconda后可以使用网页版的jupyter n…

C# 中记录(Record)详解

从C#9.0开始,我们有了一个有趣的语法糖:记录(record)   为什么提供记录? 开发过程中,我们往往会创建一些简单的实体,它们仅仅拥有一些简单的属性,可能还有几个简单的方法,比如DTO等等&#xf…

使用 CSS 实现透明效果

在 CSS 中,实现透明效果有几种方法,具体使用哪种方法取决于具体需求。以下是一些常见的方法: 使用 opacity 属性: opacity 属性可以设置整个元素的透明度,包括其所有的子元素。 .transparent { opacity: 0.5; /* 0 表…

C语言:函数栈帧的创建和销毁

目录 1.什么是函数栈帧2.理解函数栈帧能解决什么问题3.函数栈帧的创建和销毁的过程解析3.1 什么是栈3.2 认识相关寄存器和汇编指令3.3 解析函数栈帧的创建和销毁过程3.3.1 准备环境3.3.2 函数的调用堆栈3.3.3 转到反汇编3.3.4 函数栈帧的创建和销毁 1.什么是函数栈帧 在写C语言…

25/2/6 <机器人基础> 运动学中各连杆的变换矩阵求法

变换矩阵 机器人通常包含多个关节和连杆,每个关节和连杆都有自己的局部坐标系。变换矩阵能够将一个点或向量从一个坐标系转换到另一个坐标系,从而实现对机器人各个部件位置和姿态的统一描述 变换矩阵能够将复杂的运动分解为旋转和平移的组合。通过矩阵乘…

AllData数据中台核心菜单十二:数据同步平台

🔥🔥 AllData大数据产品是可定义数据中台,以数据平台为底座,以数据中台为桥梁,以机器学习平台为中层框架,以大模型应用为上游产品,提供全链路数字化解决方案。 ✨奥零数据科技官网:…

【FPGA】 MIPS 12条整数指令 【3】

实现乘除 修改框架 EX:实现带符号乘除法和无符号乘除法 HiLo寄存器:用于存放乘法和除法的运算结果。Hi、Lo为32bit寄存器。电路描述与实现RegFile思想一致 仿真 代码 DataMem.v include "define.v"; module DataMem(input wire clk,input…

文件基础IO

理解"文件" 1-1 狭义理解 文件在磁盘里磁盘是永久性存储介质,因此文件在磁盘上的存储是永久性的磁盘是外设(即是输出设备也是输入设备)磁盘上的文件 本质是对文件的所有操作,都是对外设的输入和输出简称IO 1-2 广义理…

Unity 简易的UI框架

核心内容 UIType.cs namespace MYTOOL.UI {/// <summary>/// UI层级/// </summary>public enum UILayer{/// <summary>/// 主界面层/// </summary>MainUI 0,/// <summary>/// 普通界面层/// </summary>NormalUI 1,/// <summary>/…

VUE2双向绑定的原理

文章目录 VUE2双向绑定的原理1. 什么是双向绑定2. 双向绑定的原理2.1 ViewModel的重要作用2.2 双向绑定的流程 3. 双向绑定的实现3.1 data响应化处理3.2 Compile编译3.3 依赖收集 VUE2双向绑定的原理 1. 什么是双向绑定 讲双向绑定先讲单项绑定&#xff0c;啥叫单项绑定&…

4G核心网的演变与创新:从传统到虚拟化的跨越

4G核心网 随着移动通信技术的不断发展&#xff0c;4G核心网已经经历了从传统的硬件密集型架构到现代化、虚拟化网络架构的重大转型。这一演变不仅提升了网络的灵活性和可扩展性&#xff0c;也为未来的5G、物联网&#xff08;LOT&#xff09;和边缘计算等技术的发展奠定了基础。…

HTML排版标签、语义化标签、块级和行内元素详解

目录 前言 一、HTML中的排版标签 1. 文本相关标签 1.1 标题标签 ~ 1.2 段落标签 1.3 强调和加粗 1.4 换行标签 1.5 水平线标签 二、HTML中的语义化标签 2.1 语义化标签概述 2.2 常见的语义化标签 示例&#xff08;核心代码部分&#xff09;&#xff1a; 三、HTM…