MySQL 1040 Too many connections 问题解决

 MySQL 1040 Too many connections 问题解决


MySQL服务器所支持的最大连接数是有上限的,因为每个连接的建立都会消耗内存,因此我们希望客户端在连接到MySQL Server处理完相应的操作后,应该断开连接并释放占用的内存。如果你的MySQL Server有大量的闲置连接,他们不仅会白白消耗内存,而且如果连接一直在累加而不断开,最终肯定会达到MySQL Server的连接上限数,这会报'too many connections'的错误,如下图:

产生原因:

服务器连接数已满,其可能原因有:

(1)服务器连接数设置过小,已经耗尽。

          (2)客户端长期占用连接未释放,导致连接已经耗尽。

解决方案:

(1)查看MySQL配置文件下的最大连接数值是否设置得过小:Linux系统一般在etc/my.cnf文件中,windows则查找my.ini文件:max_connections = 100     // 默认最大的连接数为100

(2)查看/设置MySQL的连接过期时间(必须同时设置):

wait_timeout=100
interactive_timeout=100
(3)重启MySQL服务器:

/etc/rc.d/init.d/mysql status                        # 查看MySQL的运行状态

mysqladmin -r root -p123456 shutdown     # 关闭MySQL服务

service mysql start                                     # 重启MySQL服务

参数描述:

1)interactive_timeout:
参数含义:服务器关闭交互式连接前等待活动的秒数。交互式客户端定义为在mysql_real_connect()中使用CLIENT_INTERACTIVE选项的客户端。
参数默认值:28800秒(8小时)
2)wait_timeout:
参数含义:服务器关闭非交互连接之前等待活动的秒数。在线程启动时,根据全局wait_timeout值或全局interactive_timeout值初始化会话wait_timeout值,取决于客户端类型(由mysql_real_connect()的连接选项CLIENT_INTERACTIVE定义)。
参数默认值:28800秒(8小时)



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值