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

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

相关推荐
IT_陈寒1 小时前
React的useState居然还有这种坑?我差点删库跑路
前端·人工智能·后端
Pedantic2 小时前
SwiftUI 手势笔记
前端·后端
金銀銅鐵2 小时前
[Python] 从《千字文》中随机挑选汉字
后端·python
飘尘5 小时前
前端转型全栈(Java后端)的快速上手指引
前端·后端·全栈
浏览器工程师6 小时前
AI Agent 接浏览器任务,先别让它一路点到底
前端·后端
行者全栈架构师6 小时前
Maven dependency:tree 的 8 个高级用法
java·后端
Chenyiax6 小时前
从一次请求看懂 OkHttp:架构、调度与连接管理
后端
爱勇宝7 小时前
深扒 Anthropic 1680 位工程师简历:应届生几乎没机会,AI 公司最缺的不是博士
前端·后端·程序员
AskHarries7 小时前
工具失败时怎么办:重试、回滚、人工确认和风险提示
后端·程序员