MySQL8.0新特性之解决too many connections

众所周知,目前数据库在超过设置最大连接数时,会报too many connections,把新的连接拒之门外,而在MariaDB 10.0和Percona5.6版本中,有个参数extra_port可以额外登陆到数据库解决这个连接问题。

MySQL官方终于在8.0.14这个版本也推出了相关参数。

主要包含几个配置参数:admin_address: 用于指定管理员发起tcp连接的主机地址,可以是ipv4,ipv6, 或者Host name等等,他类似bind-address,但不同的是只能接受一个ip地址

admin_port: 顾名思义,就是管理员用来连接的端口号,注意如果admin_address没有设置的话,这个端口号是无效的

create_admin_listener_thread: 是否创建一个单独的listener线程来监听admin的链接请求,默认值是关闭的,facebook的建议是打开,否则其会使用已有的监听线程去监听admin连接。该参数同样需要admin_address打开, 否则没有任何影响

注意必须要有权限service_connection_admin才能登陆该端口,否则会报错

根据文档描述,admin port的连接个数不受max_connection或者Max_user_connection的限制。

基于此特性,做了一些测试:

根据官方文档要求,调整了一下参数

 

 将数据库连接打满,然后通过admin_port连接数据库,

 

 

 

 通过线程表查看,正常root用户连接数据库的方式和通过admin_port连接数据库的方式不同:

 

 

 

 一个是走本地socket,而另一个是走SSL/TLS,8.0版本中加密方式也做了增强,默认都是以caching_sha2_password插件来做的,还以原来方式连接数据库就会报以下错误。

ERROR 1251 (08004): Client does not support authentication protocol requested by server; consider upgrading MySQL client        

可以选择在配置文件中加上default_authentication_plugin = mysql_native_password重新走原来的加密方式,但是不推荐再用以前的,毕竟MySQL5.7版本到明年官方就不再维护BUG了,让我们一起拥抱8.0吧。

 

 

http://mysql.taobao.org/monthly/2019/09/03/              

posted @ 2019-12-03 15:06  清歌牧言  阅读(3638)  评论(0编辑  收藏  举报