广告
返回顶部
首页 > 资讯 > 数据库 >MySQL too many connections错误的原因有哪些
  • 290
分享到

MySQL too many connections错误的原因有哪些

2023-06-14 09:06:35 290人浏览 八月长安
摘要

这篇文章将为大家详细讲解有关MySQL too many connections错误的原因有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。   今天中午,开发测试环境的Mysql服

这篇文章将为大家详细讲解有关MySQL too many connections错误的原因有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

   今天中午,开发测试环境的Mysql服务报了一个too many connections的错误,从问题上看,可能是连接池被打满了,导致所有的连接都不可用了。

   在这种情况下,最为直接的办法就是重新设置最大连接数,查看my.cnf文件,里面关于连接数的参数有两个,分别是:

max_connections:最大连接数

max_user_connections:用户最大连接数

其中,第一个参数确定的是该实例的最大连接数,第二个参数确定的是单个用户的最大连接数。

   一般的线上环境,为了保险起见,一般这两个参数不能设置为相等,可以将max_user_connections参数设置的稍微小一点,留有一定的余量,这样可以防止单个用户占用完所有的连接池。

    看到上面这个问题,我的第一反应是,登陆上去,kill掉一些连接,然而,当我想办法登陆的时候,发现已经没法登陆了,连DBA的管理账号dba_admin都已经无法建立连接了。查看错误日志

2019-08-12T06:02:42.928412Z 0 [Warning] Too many connections2019-08-12T06:02:42.930181Z 0 [Warning] Too many connections2019-08-12T06:02:44.595199Z 0 [Warning] Too many connections2019-08-12T06:02:44.597160Z 0 [Warning] Too many connections2019-08-12T06:02:44.782042Z 0 [Warning] Too many connections

   全部都是too many connections,幸亏是开发环境,这样的话,我们可以使用停止数据库服务的方法来进行重启,然后重新增加最大连接数,当然,这个增加的量需要考量,一般情况下,需要跟wait_timeout的值结合起来设置,也就是等待超时时间,一般情况下,如果wait_timeout的值比较大,往往会造成连接数比较多的情况,而一个连接会消耗大约2M左右的内存,如果你设置的连接比较多,很可能出现内存耗尽的情况,而wait_timeout的值如果设置的比较小,连接会不停的创建和销毁,这样会浪费一定的IO资源。

  所以,如何得到一个平衡的值成为关键,在mysql官方文档中有如下解释:

MySQL too many connections错误的原因有哪些

MySQL too many connections错误的原因有哪些

   从官方文档的这个说明来看,几个GB的内存完全可以支持你把连接数设置在500-1000之间,事实上,这个区间的值能够满足大部分的需求。

   除此之外,官方文档上还说了一个特点,挺好的,就是

mysqld actually permits max_connections + 1 client connections. The extra connection is reserved for use by accounts that have the SUPER privilege. By granting the privilege to administrators and not to nORMal users (who should not need it), an administrator who also has the PROCESS privilege can connect to the server and use SHOW PROCESSLIST to diagnose problems even if the maximum number of unprivileged clients are connected. 

   翻译过来就是事实上,允许的最大连接数是max_connections的值+1个连接,最后多的这个链接,是给super权限的用户用的,这样在连接被耗尽的时候,可以使用super权限登陆上去,进行show processlist的方法来查看连接,并kill掉一些不需要的连接,让服务重新可用。

     然而,实际应用中,我们经常为了操作方便,而给一些不必要的账号分配super权限,导致拥有super权限的普通用户占用了多余的这一个连接,在今天这个问题中,这样的设置却无济于事,还是无法登陆,因为,毕竟一个连接太少了,如果有其他的账号已经占用了个这个super的连接,那么这个实例还是无法访问。

   这样的情况下,除了重启mysql实例,修改my.cnf文件中的最大连接数,有没有不停止服务而进行处理方法呢,答案是有的。但是有一个前提,你的服务要是Percona-server的,如果你使用的官方版本的MySQL,那这个办法是行不通的,据说MariaDB也可以使用这个办法,没有测试过,不太懂,有兴趣的可以测一测。

   从Percona Server 5.5.29开始,您可以简单地添加extra_port到您的my.cnf,并且下次重新启动时,端口将变为可用,并将侦听与常规连接相同的bind_address。如果未设置extra_port变量,则默认情况下不会有其他端口可用。您还可以定义extra_max_connections此端口将处理的连接数。此默认值为1。

    以上所述,是Percona-Server官网上的描述,可以通过另外2个参数来实现连接池占用完之后的登陆问题:

mysql:(none) 22:12:51>>show variables like '%extra%';+----------------------------------+-------+| Variable_name                    | Value |+----------------------------------+-------+| extra_max_connections            | 10    || extra_port                       | 43130 |+----------------------------------+-------+2 rows in set (0.00 sec)

   就是这两个参数,一个是extra_max_connections,另外一个是extra_port参数,这两个参数使我们拥有额外的连接和额外的端口去连接服务器,从而使用show processlist观察连接情况,杀掉一些不必要的连接,使得服务器重新可用。

 但是需要注意的是,在Percona Server 8.0.14及更新版本中已删除extra_port,  因为MySQL社区已实现了admin_port,它复制了此功能。因此,请确保在升级到Percona Server 8.0.14时编辑my.cnf,如果已经在那里定义了extra_port,还请及时更新!

   最后我们看看连接的情况吧,在这个例子中,我们将extra_port设置成为了43130:

[root@ log]# /usr/local/mysql/bin/mysql -udba_admin -p -h227.0.0.1 -P4313Enter passWord: Welcome to the MySQL monitor.  Commands end with ; or \g.Your MySQL connection id is 71920Server version: 5.7.16-10-log Percona Server (GPL), Release 10, Revision a0c7d0dCopyright (c) 2000, 2011, oracle and/or its affiliates. All rights reserved.Oracle is a reGIStered trademark of Oracle Corporation and/or itsaffiliates. Other names may be trademarks of their respectiveowners.Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.mysql--dba_admin@127.0.0.1:(none) 22:40:59>>exitBye---------------------------------------------------------------------------[root@ log]# /usr/local/mysql/bin/mysql -udba_admin -p -h227.0.0.1 -P43130Enter password: Welcome to the MySQL monitor.  Commands end with ; or \g.Your MySQL connection id is 71941Server version: 5.7.16-10-log Percona Server (GPL), Release 10, Revision a0c7d0dCopyright (c) 2000, 2011, Oracle and/or its affiliates. All rights reserved.Oracle is a registered trademark of Oracle Corporation and/or itsaffiliates. Other names may be trademarks of their respectiveowners.Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.mysql--dba_admin@127.0.0.1:(none) 22:41:05>>

简单总结一下

  • 如果使用MySQL官方版本:

   发生连接数超过最大值的情况的时候,首先使用super全新的账户进行登陆,查看是否可以直接登陆,如果不行的话,那就只能停服务,然后重新设置连接数,在重启服务。

  • 如果使用Percona-Server或者MariaDB:

   可以尝试提前配置extra_port来防止出现连接数被占满的情况。如果一旦发生了这种情况而没有提前进行配置,那么在停止服务之后最好进行补充,以防止此类情况再次发生。

关于“MySQL too many connections错误的原因有哪些”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

您可能感兴趣的文档:

--结束END--

本文标题: MySQL too many connections错误的原因有哪些

本文链接: https://www.lsjlt.com/news/269478.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL too many connections错误的原因有哪些
    这篇文章将为大家详细讲解有关MySQL too many connections错误的原因有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。   今天中午,开发测试环境的MySQL服...
    99+
    2023-06-14
  • MySQL too many connections错误的原因及解决
       今天中午,开发测试环境的MySQL服务报了一个too many connections的错误,从问题上看,可能是连接池被打满了,导致所有的连接都不可用了。    在这种情...
    99+
    2022-05-22
    MySQL too many connections错误 MySQL 错误解决
  • Mysql报错:too many connections原因及解决方法
    原因是mysql连接数过多 解决方案: linux登录mysql:  mysql -u root -p; 查看mysql允许的最大连接数 show variables like '%max_connections%'; 查看这次mysql服...
    99+
    2023-09-03
    mysql 数据库
  • Mysql错误:Too many connections的解决方法
    MySQL数据库 Too many connections 出现这种错误明显就是 mysql_connect 之后忘记 mysql_close; 当大量的connect之后,就会出现Too many con...
    99+
    2022-10-18
  • MySQL提示“too many connections“错误的解决过程
    目录发现问题解决过程mysql限制最大连接数的原因总结发现问题 最近使用mysql5.7的时候连接公司系统数据库时发现提示报错,出现mysql too many connection...
    99+
    2022-11-13
  • MySQL报错1040'Too many connections'的原因以及解决方案
    目录报错原因:解决办法总结 MySQL 报错1040 ‘Too many connections’ 报错原因: 实际连接数超过了mysql 允许的最...
    99+
    2022-11-13
  • 解决MySQL错误Too many connections的方法是什么
    今天就跟大家聊聊有关解决MySQL错误Too many connections的方法是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。MySQL数...
    99+
    2022-10-19
  • MySQL报错1040'Too many connections'的原因以及解决方案
    目录报错原因:解决办法总结 mysql 报错1040 ‘Too many connections’ 报错原因: 实际连接数超过了mysql 允许的最大连接数,访问量过高,MySQL服务器...
    99+
    2022-07-01
    mysql报错1040 1040 too many connections
  • SQL Server错误的原因有哪些
    SQL Server错误的原因有以下几种:1. 语法错误:SQL语句语法错误,例如缺少关键字、拼写错误等。2. 运行时错误:SQL语...
    99+
    2023-09-23
    SQL Server
  • tomcat启动错误的原因有哪些
    1. JDK版本不兼容:Tomcat只能在支持的JDK版本上运行,如果使用了不兼容的JDK版本,可能会导致启动错误。2. 端口冲突:...
    99+
    2023-08-30
    tomcat
  • MySql总是提示语法错误的原因有哪些
    MySQL提示语法错误的原因可能有以下几个:1. SQL语句拼写错误:在编写SQL语句时,可能会出现拼写错误,如错误的表名、列名等。...
    99+
    2023-08-20
    MySql
  • php出现500错误的原因有哪些
    本教程操作环境:windows7系统、PHP7.1版、DELL G3电脑对于http请求报错状态码为500,通常解释是:表示服务器遇到错误,无法完成请求(即服务器内部错误),但具体问题还要具体分析,下面说下一些500问题及处理方案。一、PH...
    99+
    2020-10-10
    php 500错误
  • 域名解析错误的原因有哪些
    域名解析错误的原因有:1、分析网站空间存在问题导致域名解析错误;2、网站空间被病毒入侵,从而干扰域名被正确解析;3、网站域名设置错误导致域名无法解析成功;4、域名供货商出现故障问题,从而影响域名解析过程。具体内容如下:分析网站空间是不是存在...
    99+
    2022-10-07
  • c++运行时错误的原因有哪些
    C++运行时错误的原因有以下几种: 内存错误:内存错误是指程序试图访问未分配的内存或者试图访问已释放的内存。这包括指针错误(如空...
    99+
    2023-10-28
    c++
  • win10系统出现错误的原因有哪些
    软件错误:某些应用程序或驱动程序可能存在错误,导致系统崩溃或出现错误。 硬件问题:硬件故障,如内存问题、硬盘问题或其他硬件设备故障...
    99+
    2023-10-21
    win10
  • ubuntu下SSH连接错误的原因有哪些
    Ubuntu下SSH连接错误的原因可能有以下几种: SSH服务未启动:在Ubuntu中,默认情况下SSH服务是未启动的,需要手动...
    99+
    2023-10-22
    ubuntu ssh
  • c语言运行错误的原因有哪些
    C语言运行错误的原因主要有以下几个:1. 语法错误:C语言是一种严格的编程语言,代码中的语法错误会导致编译器无法正确解析代码,从而引...
    99+
    2023-09-18
    c语言
  • win11电脑登陆错误的原因有哪些
    Windows 11电脑登录错误的原因可能有以下几种:1. 密码错误:输入的密码与账户不匹配,或者密码输入错误。2. 用户名错误:输...
    99+
    2023-09-17
    win11
  • windows网络连接错误的原因有哪些
    这篇文章主要介绍“windows网络连接错误的原因有哪些”,在日常操作中,相信很多人在windows网络连接错误的原因有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”windows网络连接错误的原因有哪些...
    99+
    2023-07-02
  • c语言格式错误的原因有哪些
    C语言格式错误可能有以下几个原因:1. 缺少分号:在语句结束的地方忘记加上分号,导致出现语法错误。2. 括号不匹配:在函数调用、条件...
    99+
    2023-08-19
    c语言
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作