mysql运维-sleep线程过多_MySQL sleep过多解决方法

现状:

睡眠连接过多,会对mysql服务器造成什么影响?
严重消耗mysql服务器资源(主要是cpu, 内存),并可能导致mysql崩溃。

原因分析:

造成睡眠连接过多的原因?
1. 使用了太多持久连接(在高并发系统中,不适合使用持久连接)
2. 程序中,没有及时关闭mysql连接
3. 数据库查询不够优化,过度耗时。

解决:

那么,如果要从根本上解决sleep连接过多,就得从以上三点反复检查,但是见效并不快。
mysql的配置文件中,有一项:
wait_timeout, 即可设置睡眠连接超时秒数,如果某个连接超时,会被mysql自然终止,多好的办法!

如在MySQL的my.ini中设置:
wait_timeout=100 #即设置mysql连接睡眠时间为100秒,任何sleep连接睡眠时间若超过100秒,将会被mysql服务自然终止。

那么,对于正在运行中的生产服务器,在不能停止服务情况下,修改此项怎么办?很简单,以root用户登录到mysql,执行:

set global interactive_timeout=30;
set global wait_timeout=100

更根本的方法,还是从以上三点排查之:

  1. 在PHP程序中,不使用持久链接,即使用mysql_connect而不是pconnect。
  2. PHP程序执行完毕,应该显式调用mysql_close
  3. Java程序调整连接池(C3P0)或者调整Java服务(Tomcat有关连接池参数)
  4. 逐步分析系统的SQL查询,找到查询过慢的SQL,进行优化

显示连接列表
在这里插入图片描述
在Navicat Premium中可以看到很多处于sleep状态的连接,那怎么让MySQL自动关闭这些处理sleep状态的连接呢?

wait_timeout、interactive_timeout 默认值:

SHOW GLOBAL VARIABLES LIKE 'wait_timeout';
SHOW GLOBAL VARIABLES LIKE 'interactive_timeout';

set global wait_timeout=30;
set global interactive_timeout=30;

注:wait_timeout要与interactive_timeout一起修改才能起效。
这种修改方式在重启mysql服务后,会失效,所以最好还是把这两个属性配置到mysql配置文件中。

附注:

利用mysql -e 参数引出的重要命令:

-- 1. 查看数据库正在执行的SQL语句,可能无法看全完整的SQL语句
show processlist;
-- 2. 查看正在执行的完整的SQL语句,完整显示
show full processlist;
-- 3. 查看配置参数,my.cnf里参数的生效情况
show variables;
-- 4. 杀掉SQL线程
kill ID;
-- 5. 查看当前会话的数据库状态信息
show session status;
-- 6. 查看整个数据库运行的状态信息,很重要,要分析并要做好监控
show global status;
-- 7. 显示innodb引擎的性能状态
show engine innodb status;
  • 2
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

若行若冲

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值