zoukankan      html  css  js  c++  java
  • MySQL 5.7 Sleep 连接太多的处理方式

    睡眠连接过多,会对mysql服务器造成什么影响?

    严重消耗mysql服务器资源(主要是cpu, 内存),并可能导致mysql崩溃。

    造成睡眠连接过多的原因?

    1. 使用了太多持久连接(个人觉得,在高并发系统中,不适合使用持久连接)

    2. 程序中,没有及时关闭mysql连接

    3. 数据库查询不够优化,过度耗时。

    那么,如果要从根本上解决sleep连接过多,就得从以上三点反复检查,但是见效并不快。

    网上有人分享,使用shell脚本配合cron,定期杀死睡眠时间太久的连接,但是这种方法非常不可取,典型的以暴制暴,很可能导致数据崩溃,而且,还需要编写相应shell, 设置cron, 实施成本较繁琐,不推荐使用。

    那么更好的办法应该是让mysql自己决定这些睡眠连接的命运,实施会更简单,有效。

    mysql的配置文件中,有一项:

    wait_timeout, 即可设置睡眠连接超时秒数,如果某个连接超时,会被mysql自然终止,多好的办法!

    如设置: 

    wait_timeout=100 #即设置mysql连接睡眠时间为100秒,任何sleep连接睡眠时间若超过100秒,将会被mysql服务自然终止,要比编写shell脚本更简单。

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

    set global wait_timeout=100

    即可。

    在我的生产环境中,使用这个办法,取得了相当好的效果。

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

    1. 程序中,不使用持久链接,即使用mysql_connect而不是pconnect。

    2.   程序执行完毕,应该显式调用mysql_close

    3. 只能逐步分析系统的SQL查询,找到查询过慢的SQL,优化之

    如下图所示: 

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

    wait_timeout默认值: 
    这里写图片描述 
    interactive_timeout默认值: 
    这里写图片描述

    编辑 /etc/my.cnf,在mysqld 下 新增 timeout参数,设置为120秒,如下:

    【mysqld】
    wait_timeout=120
    interactive_timeout=120

    注意:要同时设置interactive_timeout和wait_timeout才会生效。

    最后重启一下mysql 生效 即可!

  • 相关阅读:
    jquery验证手机号码和固定电话号码
    window下安装mongodb及php mongo扩展
    Html form 表单提交前验证
    验证电话号码中间四位加※
    php方法 隐藏手机号中间四位
    win7 64位安装redis 及Redis Desktop Manager使用
    Redis系列-远程连接redis并给redis加锁
    使用密码记录工具keepass来保存密码
    【消息队列MQ】各类MQ比较
    Syslog-ng
  • 原文地址:https://www.cnblogs.com/friendwang1001/p/15555282.html
Copyright © 2011-2022 走看看