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;"

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

相关推荐
希望永不加班20 小时前
Spring AOP 代理模式:CGLIB 与 JDK 动态代理区别
java·开发语言·后端·spring·代理模式
浮游本尊21 小时前
一次合同同步背后的多阶段流水线:从外部主数据到本地歧义消解
后端
lv__pf21 小时前
springboot原理
java·spring boot·后端
段小二1 天前
服务一重启全丢了——Spring AI Alibaba Agent 三层持久化完整方案
java·后端
UIUV1 天前
Go语言入门到精通学习笔记
后端·go·编程语言
lizhongxuan1 天前
开发 Agent 的坑
后端
段小二1 天前
Agent 自动把机票改错了,推理完全正确——这才是真正的风险
java·后端
itjinyin1 天前
ShardingSphere-jdbc 5.5.0 + spring boot 基础配置 - 实战篇
java·spring boot·后端
Victor3561 天前
MongoDB(91)如何在MongoDB中使用TTL索引?
后端