龙空技术网

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

IT168企业级 365

前言:

目前各位老铁们对“mysql连接数满了”都比较关切,大家都想要知道一些“mysql连接数满了”的相关文章。那么小编也在网上搜集了一些对于“mysql连接数满了””的相关文章,希望兄弟们能喜欢,我们快快来了解一下吧!

提到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”来访问您的数据库。

标签: #mysql连接数满了