Too many connections错误

Posted superchong

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Too many connections错误相关的知识,希望对你有一定的参考价值。

一,错误分析:

  my.ini 中设定的并发连接数太少或者系统繁忙导致连接数被占满。

  连接数超过了 mysql 设置的值,与 max_connections 和 wait_timeout  都有关。

  wait_timeout 的值越大,连接的空闲等待就越长,这样就会造成当前连接数越大。

解决方式:

打开 MYSQL 安装目录打开 my.ini 找到 max_connections 默认是 100, 一般设置到500~1000比较合适,重启 MySQL 

显示哪些线程正在运行

show full processlist

状态:
1. SLEEP
线程正在等待客户端发送新的请求。
2. QUERY
线程正在执行查询或者正在将结果发送给客户端。 
3. LOCKED
在MYSQL服务层,该线程正在等待表锁。在存储引擎级别实现的锁,如INNODB的行锁,并不会体现在线程状态中。 对于MYISAM来说这是一个比较典型的状态。但在其他没有行锁的引擎中也经常会出现。 
4. ANALYZING AND STATISTICS
线程正在收集存储引擎的统计信息, 并生成查询的执行计划。
5. COPYING TO TMP TABLE (ON DISK)
线程正在执行查询, 并且将其结果集都复制到一个临时文件中, 这种状态一般要么是在做GROUP BY操作,要么是文件排序操作, 或者是UNION操作。 如果这个状态后面还有ON DISK的标 , 那表示MYSQL正在将一个内存临时表放到磁盘上。

6. SORTING RESULT
线程正在对结果集进行排序。

7. SENDING DATA
线程可能在多个状态之间传送数据,或者生成结果集,或者在向客户端返回数据。

 

连接数设置多少是合理的?

查看mysql的最大连接数:

show variables like ‘%max_connections%‘;

查看服务器响应的最大连接数:

show global status like ‘Max_used_connections‘;

 

对于mysql服务器最大连接数值的设置范围比较理想的是:服务器响应的最大连接数值占服务器上限连接数值的比例值在10%以上,如果在10%以下,说明mysql服务器最大连接上限值设置过高。

wait_timeout

wait_timeout — 指的是mysql在关闭一个非交互的连接之前所要等待的秒数,初始值是28800

wait_timeout 过大有弊端,其体现就是MySQL里大量的SLEEP进程无法及时释放,拖累系统性能,不过也不能把这个指设置的过小,否则你可能会遭遇到“MySQL has gone away”之类的问题

查看

 show global variables like ‘wait_timeout‘;  

设置

set global wait_timeout=100;  

 













以上是关于Too many connections错误的主要内容,如果未能解决你的问题,请参考以下文章

解决Mysql错误Too many connections的方法

解决Mysql错误Too many connections的方法

MySQL数据库 Too many connections

针对mySQL的错误Too many connections的解决方案

网站时常出现too many connection的错误

解决mysql 1040错误Too many connections的方法