MySQL性能排查实战:大量Sleep空闲连接导致数据库写入缓慢解决方案

一、问题现象

业务反馈 MySQL 数据库读操作正常,但写操作(INSERT/UPDATE/DELETE)耗时极长,业务接口出现明显卡顿、响应超时,数据库整体性能异常。

二、问题排查

  1. 执行连接状态查询 登录MySQL执行核心排查命令:
sql 复制代码
show full processlist;

排查结果

  • 数据库连接数高达 700~800个
  • 所有连接状态几乎全为 Sleep(空闲连接)
  • 无锁等待、无长事务、无慢查询阻塞
  • 存在大量未认证连接,MySQL资源被严重消耗
  1. 慢查询日志检查
sql 复制代码
show variables like '%slow%';

发现慢查询日志处于关闭状态,排除慢SQL导致的性能问题。

  1. 根因定位 应用服务连接池配置不合理,未正确释放数据库连接,导致大量空闲连接持续堆积,耗尽MySQL内存、CPU、IO资源,最终引发写入性能急剧下降(读可命中缓存,写需磁盘IO,受资源耗尽影响更严重)。

三、解决方案

方案1:急救处理 - 批量清理所有空闲连接

通过Linux命令行无格式、批量、安全清理所有Sleep空闲连接,无需手动复制粘贴,无语法报错:

bash 复制代码
# 1. 生成纯文本清理脚本(无表格格式,纯净SQL)
mysql -uroot -p'【数据库密码】' -N -e "SELECT CONCAT('KILL ',id,';') FROM information_schema.processlist WHERE command='Sleep'" > /tmp/kill_sleep.sql

# 2. 一键执行脚本,清理所有空闲连接
mysql -uroot -p'【数据库密码】' < /tmp/kill_sleep.sql

方案2:根治处理 - 设置连接自动超时(永久解决)

清理连接后,配置MySQL自动断开空闲连接,从根本上杜绝连接堆积:

bash 复制代码
mysql -uroot -p'【数据库密码】' -e "SET GLOBAL wait_timeout=60; SET GLOBAL interactive_timeout=60;"
  • wait_timeout=60:非交互式连接空闲60秒自动断开
  • interactive_timeout=60:交互式连接空闲60秒自动断开

四、效果验证

执行命令验证连接数,连接数会从 700+ 骤降至 20以内,数据库性能立即恢复:

bash 复制代码
# 统计连接数
mysql -uroot -p'【数据库密码】' -e "show full processlist;" | wc -l

# 查看完整连接状态
mysql -uroot -p'【数据库密码】' -e "show full processlist;"

清理完成后,数据库写操作恢复正常速度,业务卡顿问题彻底解决。

相关推荐
绝知此事2 分钟前
ELK 从入门到精通:Spring Boot 实战三部曲(一)—— 基础核心与快速上手
spring boot·后端·elk
土狗TuGou7 分钟前
SQL内功笔记 · 第5篇:SQL逻辑执行顺序
数据库·笔记·后端·sql·mysql
为思念酝酿的痛9 小时前
POSIX信号量
linux·运维·服务器·后端
小羊在睡觉9 小时前
力扣84. 柱状图中最大的矩形
后端·算法·leetcode·golang·go
swipe10 小时前
Neo4j + Graph RAG 医疗知识图谱工程实践:患者教育问答真正需要的是“关系可追溯”
后端·langchain·llm
源码宝10 小时前
MES系统源码:Java8 + SpringBoot2.7 + MySQL8 + Redis,后端源码清爽易扩展
java·后端·源码·springboot·mes系统·源码二开·mes源码
金銀銅鐵11 小时前
[Java] 如何理解 class 文件中方法的 descriptor?
java·后端
村口张大爷11 小时前
05 — 分层架构与依赖倒置
后端·架构·系统架构
Jasonakeke12 小时前
SpringBoot自动配置原理揭秘
java·spring boot·后端
IT_陈寒13 小时前
Vite热更新失灵?你可能漏了这个配置
前端·人工智能·后端