MySQL too many connections错误的原因及解决
在数据库实战开发的过程中,我们经常会遇到一些这样那样的问题,然后要卡好半天,等问题解决了才发现原来一些细节知识点还是没有掌握好。今天golang学习网就整理分享《MySQL too many connections错误的原因及解决》,聊聊MySQL错误,希望可以帮助到正在努力赚钱的你。
今天中午,开发测试环境的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 connections 2019-08-12T06:02:42.930181Z 0 [Warning] Too many connections 2019-08-12T06:02:44.595199Z 0 [Warning] Too many connections 2019-08-12T06:02:44.597160Z 0 [Warning] Too many connections 2019-08-12T06:02:44.782042Z 0 [Warning] Too many connections
全部都是too many connections,幸亏是开发环境,这样的话,我们可以使用停止数据库服务的方法来进行重启,然后重新增加最大连接数,当然,这个增加的量需要考量,一般情况下,需要跟wait_timeout的值结合起来设置,也就是等待超时时间,一般情况下,如果wait_timeout的值比较大,往往会造成连接数比较多的情况,而一个连接会消耗大约2M左右的内存,如果你设置的连接比较多,很可能出现内存耗尽的情况,而wait_timeout的值如果设置的比较小,连接会不停的创建和销毁,这样会浪费一定的IO资源。
所以,如何得到一个平衡的值成为关键,在MySQL官方文档中有如下解释:
从官方文档的这个说明来看,几个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 -h127.0.0.1 -P4313 Enter password: Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 71920 Server version: 5.7.16-10-log Percona Server (GPL), Release 10, Revision a0c7d0d Copyright (c) 2000, 2011, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. 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>>exit Bye --------------------------------------------------------------------------- [root@ log]# /usr/local/mysql/bin/mysql -udba_admin -p -h127.0.0.1 -P43130 Enter password: Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 71941 Server version: 5.7.16-10-log Percona Server (GPL), Release 10, Revision a0c7d0d Copyright (c) 2000, 2011, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. 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错误的原因及解决》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于mysql的知识点!

- 上一篇
- MySQL source命令的使用简介

- 下一篇
- 浅谈MySQL如何优雅的做大表删除
-
- 热心的裙子
- 这篇博文真及时,作者大大加油!
- 2023-03-24 09:13:08
-
- 单身的手机
- 真优秀,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢作者大大分享技术文章!
- 2023-03-06 05:54:11
-
- 酷酷的野狼
- 这篇博文真及时,太详细了,很好,收藏了,关注up主了!希望up主能多写数据库相关的文章。
- 2023-02-08 14:06:28
-
- 能干的西牛
- 太细致了,mark,感谢师傅的这篇技术贴,我会继续支持!
- 2023-01-04 15:12:33
-
- 数据库 · MySQL | 2小时前 |
- MySQL无法启动?8个排查方法全解析
- 174浏览 收藏
-
- 数据库 · MySQL | 4小时前 |
- 主键与唯一键区别,如何选主键?
- 166浏览 收藏
-
- 数据库 · MySQL | 6小时前 |
- MySQL多表连接优化技巧与实战策略
- 221浏览 收藏
-
- 数据库 · MySQL | 18小时前 |
- MySQL排序优化与性能提升技巧
- 153浏览 收藏
-
- 数据库 · MySQL | 20小时前 |
- MySQL中WHERE与HAVING的区别详解
- 340浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL排序优化与性能提升技巧
- 368浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL连接池配置与优化方法
- 297浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQLGROUPBY使用技巧与常见问题
- 306浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL缓存优化技巧分享
- 392浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL安装到D盘教程及路径设置详解
- 279浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL缓存设置及查询作用解析
- 470浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 511次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 498次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- 千音漫语
- 千音漫语,北京熠声科技倾力打造的智能声音创作助手,提供AI配音、音视频翻译、语音识别、声音克隆等强大功能,助力有声书制作、视频创作、教育培训等领域,官网:https://qianyin123.com
- 96次使用
-
- MiniWork
- MiniWork是一款智能高效的AI工具平台,专为提升工作与学习效率而设计。整合文本处理、图像生成、营销策划及运营管理等多元AI工具,提供精准智能解决方案,让复杂工作简单高效。
- 89次使用
-
- NoCode
- NoCode (nocode.cn)是领先的无代码开发平台,通过拖放、AI对话等简单操作,助您快速创建各类应用、网站与管理系统。无需编程知识,轻松实现个人生活、商业经营、企业管理多场景需求,大幅降低开发门槛,高效低成本。
- 107次使用
-
- 达医智影
- 达医智影,阿里巴巴达摩院医疗AI创新力作。全球率先利用平扫CT实现“一扫多筛”,仅一次CT扫描即可高效识别多种癌症、急症及慢病,为疾病早期发现提供智能、精准的AI影像早筛解决方案。
- 98次使用
-
- 智慧芽Eureka
- 智慧芽Eureka,专为技术创新打造的AI Agent平台。深度理解专利、研发、生物医药、材料、科创等复杂场景,通过专家级AI Agent精准执行任务,智能化工作流解放70%生产力,让您专注核心创新。
- 98次使用
-
- mysql数据库中1045错误的解决方法
- 2022-12-30 252浏览
-
- Mysql错误Every derived table must have its own alias解决方法
- 2023-01-16 306浏览