一 产生too many connections 的直接缘由mysql
由于数据库提供的链接被所有占满了sql
链接数超过了 MySQL 设置的值,与 max_connections 和 wait_timeout 都有关系。
wait_timeout 的值越大,链接的空闲等待就越长,这样就会形成当前链接数越大数据库
SHOW VARIABLES LIKE 'wait_timeout' 查看链接的空闲等待时间spa
set global wait_timeout=2800; 设置链接的空闲等待时间 (毫秒)线程
查看命令:show processlist; 查看现有线程数。show processlist命令显示的是Thread_connected,SHOW VARIABLES LIKE "MAX_CONNECTIONS" ; 查看最大线程数 ,当Thread_connected与max_connections相等时,在 企图进行数据库链接,就会出现too many connections的错误rest
二 解决办法ssl
# vi /etc/my.cnf 添加如下行it
[mysqld]
set-variable=max_connections=1000io
set-variable=max_user_connections=500service
set-variable=wait_timeout=200
service mysql restart