Mysql Too many connections解决方案
admin
2023-04-18 23:04:30
0

Too many connections
从字面理解,mysql连接数过多。当连接数量过多,且来不及释放时便会出现此错误。

查看mysql当前连接信息,特别要注意sleep休眠状态的连接。

show full processlist;

Command 状态:

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

查看mysql设置的最大连接数

show global variables like 'max_connections';

服务器响应的最大连接数

show global variables like 'max_user_connections';

建议:服务器响应的最大连接数值占服务器上限连接数值的比例值在10%以上,如果在10%以下,说明mysql服务器最大连接上限值设置过高。

max_user_connections/max_connections * 100% >=10%

如果最大连接数量没问题,而sleep休眠状态的连接过多,则应该从两方面注意:

  • 1。 wait_timeout 空闲等待超时时间
  • 2。 interactive_timeout 交互超时时间(通过mysql客户端连接数据库是交互式连接)

需要主题:wait_timeout设置过大有弊端,其体现就是MySQL里大量的SLEEP进程无法及时释放,拖累系统性能。如果设置过小,可能会遭遇到“MySQL has gone away”之类的问题。

要想从根本上解决sleep过多的问题,需从以下面三点排查:

  • 1。程序连接mysql,不使用持久链接。即使用mysqli_connect而不是pconnect。
  • 2。程序执行结束,主动显式调用mysqli_close来释放连接资源。
  • 3。解决程序中的SQL慢查询语句。

最后快速解决过程

set GLOBAL max_connections = 500;
set GLOBAL wait_timeout = 300;
set GLOBAL interactive_timeout = 600;

相关内容

热门资讯

苏州率先打造数据流通利用新范式 数据,作为第五大生产要素 具有流动性强、非消耗性、非均质性等特点 苏州率先打造数据流通利用新范式 夯...
伊媒披露伊美新一轮谈判5个先决... 当地时间5月12日,据伊朗法尔斯通讯社援引知情人士消息报道,伊朗对与美国新一轮谈判提出的5个先决条件...
英国将向霍尔木兹海峡多国护航行... 当地时间12日,总台记者从英国国防部获悉,英国将向在霍尔木兹海峡执行任务的多国护航行动提供无人机、战...
强化技术引领场景培育政策保障 ... 5月11日,省长叶建春就脑机接口技术与产业创新工作开展专题调研。他强调,脑机接口是培育未来产业发展新...
上海交大王如竹教授领衔撰写的“... 4月30日,国际制冷学会(IIR,International Institute of Refrig...
非人类身份蔓延:智能体AI真正... 长期以来,企业依赖服务账户、API密钥、OAuth令牌等各类非人类身份凭证,使不同服务能够在数字环境...
脑机接口“狂飙” 从病房走向多... (记者 陈锦锋)当大脑的神经信号能够直接与外部设备对话,“心想事成”便从科幻走向现实。近日,中南大学...
中巴外长通话,王毅:希望巴方保... 2026年5月12日晚,中共中央政治局委员、外交部长王毅同巴基斯坦副总理兼外长达尔通电话。达尔介绍了...
美参议院投票批准凯文·沃什出任... △凯文·沃什(资料图)当地时间5月12日,美国参议院投票批准凯文·沃什出任美联储主席,目前相关投票程...
缺油!日本快撑不住了 日本零食巨头卡乐比为节省油墨竟将原本漂亮的包装改成了黑白两色,从“喜食”变得看上去像“丧食”。日本石...