前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MYSQL 8 Too many connections error 还在继续,这对DBA 是不公平的

MYSQL 8 Too many connections error 还在继续,这对DBA 是不公平的

作者头像
AustinDatabases
发布2023-09-06 09:06:30
2010
发布2023-09-06 09:06:30
举报
文章被收录于专栏:AustinDatabases

提到MYSQL Too Many connections 这个错误在MYSQL 5.7 是一个DB人员忘不掉的错误。产生这个问题可能和数据库配置的不佳,或者应用程序组件中的缓冲池调整,增加更多的应用等等,或者因为突发的性能问题导致的这些种种,而不公平问题在于,这些情况的发生大多不是DB 可以控制的。

而在产生了 error 1040 (08004):too many connections 的错误后,如何解决才是一个难题。首先我们知道 max_connections 是一个可以动态调整的参数,但当你遇到这个问题的时候,你可能已经无法连接到数据,在进行问题的处理。

如果是使用 PERCONA MYSQL 的同学会非常轻松的解决这个问题,我们来回顾这个问题

在Percona MySQL中,您可以通过保留一个管理员连接来确保即使在达到max_connections 限制时,仍然可以向服务器发出管理命令。以下是如何保留管理员连接的步骤:

打开 MySQL 配置文件(my.cnf),通常位于 /etc/my.cnf。

在 [mysqld] 部分添加以下配置:

extra_port = 3307

extra_max_connections = 1

extra_port 是您为管理员保留的特殊端口(这个例子中是3307),而 extra_max_connections 是允许在该端口上建立的最大连接数。

保存并关闭配置文件。

重启 Percona MySQL 以应用更改:

sudo service mysql restart

或者使用 systemd:

sudo systemctl restart mysql

现在,当普通用户连接超过 max_connections 限制时,您仍然可以在保留的管理员端口上与服务器建立连接。要使用管理员连接,请使用以下命令行:

mysql -u<username> -p<password> -P3307 -h127.0.0.1

请务必将 <username> 和 <password> 替换为具有管理员权限的用户凭据。

但是 ,但是 ,但是 ,重要的事情的说三遍,如果你使用的是官版的 MYSQL,则你是没有办法的,相信MYSQL的官方也意识到这个问题,所有在 8.014 这个版本后启动了管理员的接口,这需要对管理员的数据库账号赋予 service_connection_admin 的权限,这是

从MySQL 8.0.14开始,引入了一种新的“管理连接”或“管理网络接口”功能。此功能允许通过管理员端口连接到数据库,且对管理连接数没有限制。这个特性与前面示例中显示的单个连接的区别在于,它是一个不同的端口,并且如果需要的话,可以允许多个管理连接而不仅限于一个。当用户连接耗尽时,这应该允许我们访问数据库,并从那里开始增加连接或终止某些应用程序连接。

启用“管理连接”的最简单方法是定义“admin_address”变量,这是管理连接将监听的IP地址。例如,如果您只想允许本地连接,可以将此变量定义为“127.0.0.1”,或者如果您希望通过网络连接,可以将此变量定义为服务器的IP地址。这个变量不是动态的,这意味着它需要重新启动数据库。默认情况下,此变量为空,表示禁用了管理接口。另一个相关的变量是“admin_port”;此变量定义了MySQL将用于管理连接的端口,该变量的默认值是33062。一旦您定义了这两个变量并重新启动数据库,您将在错误日志中看到一条消息,指示管理接口已准备好建立连接。

那么为什么这个在MSYQL 8.014 的新功能比之前的PERCONA 或MARIADB 的功能要好,这里可以总结一下

1 参数简洁,方便理解和设置

2 在大多数的系统中,由于存在应用账号使用管理员的账号进行连接的情况(我很鄙视,但是很多公司都在这样搞,原因就不说了,懂得都懂),那么percona 的方式就直接作废了。

基于以上的原因,MYSQL8,014 提出的这个新的功能,直接弥补了这个问题,这个方案的最大的优点是访问的地址是不一样的,即使应用使用了管理的地址进行应用的访问,导致连接打满,但我们的管理员是通过给定的新的地址进行访问,这样从安全性和问题解决的部分都比之前的方案要更稳妥。

我们做一个实验,当前最大的连接数是 300,我们同时通过管理员账号,发起300个并发连接,同时我们在通过管理员账号来连接数据库,在通过我们刚才设置的新的MYSQL TOO MANY CONNECTIONS 的8.014 的特性进行连接,下图很明显,我们连接成功,而普通的方式则不可以,已经 too many connections 了。

如果您正在使用MySQL 8.0.14或更高版本,那么应启用管理接口。正如我们所见,启用此功能非常简单,并通过允许在出现“ERROR 1040 (08004): Too many connections”的情况下访问数据库,为DBA提供了强大的功能。这个新功能不会影响正常的数据库性能并为DBA带来巨大的优势。请考虑仅将权限“SERVICE_CONNECTION_ADMIN”添加给管理用户而非应用程序用户,以免滥用此功能。如果您仍在使用较低版本的Percona Server for MySQL,请记住,在面临最大连接数问题时,可以通过配置变量“extra_port”和“extra_max_connections”来访问您的数据库。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2023-06-01,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 AustinDatabases 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 MySQL
腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档