Too many connections解决方案

Posted

tags:

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

参考技术A 2    连接数超过了mysql 设置的值,与max_connections和wait_timeout都有关。 

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

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

2     显示哪些线程正在运行    

3      查看连接数,可以发现有很多连接处于sleep状态,这些其实是暂时没有用的,所以可以kill掉

4   修改最大连接数,但是这不是一劳永逸的方法,应该要让它自动杀死那些sleep的进程。

状态:

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  的最大连接数:   应该是与上面查询到的连接数相同,才会出现too many connections的情况

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

服务器响应的最大连接数为3,远低于mysql服务器允许的最大连接数值

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

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

如果你没有修改过MySQL的配置,wait_timeout的初始值是28800

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

“MySQL has gone away”  之类的问题。

mysql终端查看timeout的设置

数据库too many connections 解决方法

问题:网站后台突然报错了,显示“too many connections........”这是咋回事?

解决:

  先罗列几个有用的操作:

  ① mysql -u root -p  回车输入密码进入mysql

  ② show processlist;  查看连接数,可以发现有很多连接处于sleep状态,这些其实是暂时没有用的,所以可以kill掉

  ③ show variables like "max_connections";  查看最大连接数,应该是与上面查询到的连接数相同,才会出现too many connections的情况

  ④ set GLOBAL max_connections=1000;  修改最大连接数,但是这不是一劳永逸的方法,应该要让它自动杀死那些sleep的进程。

  ⑤ show global variables like ‘wait_timeout‘;  这个数值指的是mysql在关闭一个非交互的连接之前要等待的秒数,默认是28800s

  ⑥ set global wait_timeout=300;  修改这个数值,这里可以随意,最好控制在几分钟内  

  ⑦ set global interactive_timeout=500;  修改这个数值,表示mysql在关闭一个连接之前要等待的秒数,至此可以让mysql自动关闭那些没用的连接,但要注意的是,正在使用的连接到了时间也会被关闭,因此这个时间值要合适

我的解决方法:

     ① select concat(‘KILL ‘,id,‘;‘) from information_schema.processlist where user=‘root‘; 先把要kill的连接id都查询出来

  ②  复制中间的kill id; 

    ③ 把修改过的内容复制回终端,最后按回车执行

 

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

mysql too many connection 解决办法

Mysql 解决Too many connections

Too many connections解决方案

mysql too many connection(1040)解决办法

MySQL提示“too many connections”的解决办法

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