Too many connections linux环境下mysql连接过多

分析原因:
   my.cnf 中设定的并发连接数太少或者系统繁忙导致连接数被占满。
  连接数超过了 MySQL 设置的值,与 max_connections 和 wait_timeout 都有关。
  wait_timeout 的值越大,连接的空闲等待就越长,这样就会造成当前连接数越大。
解决方式:
一般进入/etc目录下,找到并打开my.cnf文件找到 max_connections 默认是 100, 一般设置到500~1000比较合适,重启 MySQL

  • 进入etc目录下
     cd /etc/
  • 修改my.cnf文件
  vim my.cnf 

    [mysqld]
    basedir=/home/console/mysql
    datadir=/home/console/mysql/data
    port=3306
    server-id=2
    log-bin=mysql-bin
    max_connections=500
    max_connect_errors=30
    default-storage-engine=InnoDB
    transaction_isolation=REPEATABLE-READ
    socket=/home/console/mysql/tmp/mysql.sock
    sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
    interactive_timeout=8640000000
    wait_timeout=8640000000
    [client]
    socket=/home/console/mysql/tmp/mysql.sock
    [mysqld]
    init_connect='SET collation_connection = utf8_unicode_ci'
    init_connect='SET NAMES utf8'
    character-set-server=utf8
    collation-server=utf8_unicode_ci
    skip-character-set-client-handshake
    [client]
    default-character-set=utf8
    [mysqld_safe]
    log-error=/var/log/mysqld.log
    pid-file=/var/run/mysqld/mysqld.pid
  • 停止mysql,进入mysql安装目录
    cd /home/console/mysql/
     ./sbin/stop-mysql.sh 
  • 启动mysql
     ./sbin/start-mysql.sh

设置完成之后,基本可以解决 Too many connections 问题。

  • 进入mysql bin 目录下连接mysql
 bin]# ./mysql -uroot -pxxx
  • 查看连接池线程情况
    mysql> show full processlist;
    +------+------+----------------------+----------------+---------+------+----------+-----------------------+
    | Id   | User | Host                 | db             | Command | Time | State    | Info                  |
    +------+------+----------------------+----------------+---------+------+----------+-----------------------+
    |   96 | root | xxxx:37974           | fairylandTotal | Sleep   | 2066 |          | NULL                  |
    |   97 | root | xxx:37975            | fairylandTotal | Sleep   |  771 |          | NULL                  |
    |  174 | root | xxx:38175            | fairylandTotal | Sleep   | 2882 |          | NULL                  |
    |  299 | root | xxx:38277            | fairylandTotal | Sleep   |    3 |          | NULL                  |
    |                                                                                                         |
    |                        . . . . . . . . . .  . .   . . .  .  .                                           |
    +------+------+----------------------+----------------+---------+------+----------+-----------------------+

    66 rows in set (0.01 sec)

连接池线程状态:
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最大连接数量
    mysql> show variables like '%max_connections%';
    +-----------------+-------+
    | Variable_name   | Value |
    +-----------------+-------+
    | max_connections | 500   |
    +-----------------+-------+
    1 row in set (0.04 sec)
  • 查看mysql当前连接数量
  mysql> show global status like 'Max_used_connections';
   +----------------------+-------+
   | Variable_name        | Value |
   +----------------------+-------+
   | Max_used_connections | 155   |
   +----------------------+-------+
   1 row in set (0.22 sec)

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

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

wait_timeout 设置也很关键,设置时间过长较耗性能,设置过短经常报“MySQL server has gone away”,一般根据项目具体情况设置。本项目设置的较长造成了很多连接处于Sleep状态。对于wait_timeout的设置建议详细了解一下 https://blog.csdn.net/mashengwang/article/details/54814250

你可能感兴趣的:(Too many connections linux环境下mysql连接过多)