8.0.17版本 mysql-connection_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/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值