mysql连接报异常:Host ‘x.x.x.x’ is blocked because of many connection errors; unblock with ‘mysqladmin flush-hosts’
1. 问题描述
这个问题出现在我学习Seata 2.0版本的时候,在安装Seata并选择mysql做数据源(mode)的时候,配置远程mysql连接,启动Seata时报错:
Host 'x.x.x.x' is blocked because of many connection errors; unblock with 'mysqladmin flush-hosts'
从字面上理解就是太多连接错误了,以至于后来的连接被封锁。有一说一,Seata 2.0版本在这个地方做的不是很好,无间隔重试,如果在连接失败后间隔更长时间测试连接会更好。
我以为是Seata被封锁了,后来使用sqlyog连接,错误也是如此:
而访问我线上的网站,请求正常,也就是说,这是针对ip进行封禁。
2. 解决方案
推荐文章,分析的很细致
https://blog.csdn.net/iris_xuting/article/details/102689000
因为这个问题很少见,所以我采用的是临时解决办法,即刷新host,差不多就是将封禁的host记录刷新
有多种方式可以实现这效果
-
通过mysql命令:
进到服务器进到mysql
mysql -u root -p
然后执行
flush hosts;
或者
truncate Performance_chema.host_cache;
-
通过mysqladmin
查找mysqladmin位置,一般安装mysql不会将mysqladmin命令设置全局
whereis mysqladmin
进到mysqladmin所在目录,执行
./mysqladmin flush-hosts
我使用的是 flush hosts;
命令,好用!
至此全文结束。