zoukankan      html  css  js  c++  java
  • Mysql 提示too many connections

    原因:

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

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

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

    解决方式:

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

    显示哪些线程正在运行:

    show full processlist;

    停掉没必要的服务连接进程:
    kill 进程号(列表第一列ID就是数据库连接进程号)

    状态:
    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在关闭一个非交互的连接之前所要等待的秒数

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

    wait_timeout 过大有弊端,其体现就是MySQL里大量的SLEEP进程无法及时释放,拖累系统性能,

    不过也不能把这个指设置的过小,否则你可能会遭遇到“MySQL has gone away”之类的问题

    查看:

    show global variables like 'wait_timeout';   

    设置:

    set global wait_timeout=100;  
    

    interactive_time

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

    set global  interactive_timeout=300;
    

    mysql终端查看timeout的设置

    show global variables like '%timeout%'; 
    

      

    总结

    MySQL服务器所支持的最大连接数是有上限的,因为每个连接的建立都会消耗内存,因此客户端在连接到MySQL Server处理完相应的操作后,应该断开连接并释放占用的内存。

    如果MySQL Server有大量的闲置连接,不仅会白白消耗内存,而且如果连接一直在累加而不断开,最终肯定会达到MySQL Server的连接上限数,这会报'too many connections'的错误。

    对于wait_timeout的值设定,应该根据系统的运行情况来判断。在系统运行一段时间后,可以通过show processlist命令查看当前系统的连接状态,如果发现有大量的sleep状态的连接进程,则说明该参数设置的过大,可以进行适当的调整小些。

      

    参考:https://www.cnblogs.com/baby123/p/5710787.html

  • 相关阅读:
    sql 删除表数据并使ID自增重置
    PHP的常用字符串处理
    一个http请求的详细过程
    elasticsearch7.7-postman-json脚本
    elasticsearch7.7入门三-小试牛刀-批量导入json数据
    elasticsearch7.7入门三-小试牛刀
    elasticsearch7.7入门二-安装
    elasticsearch7.7入门一-介绍
    java8新特性七-Date Time API
    java8新特性五-Stream
  • 原文地址:https://www.cnblogs.com/wongzzh/p/15205934.html
Copyright © 2011-2022 走看看