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小时)