启动本地项目时,由于nacos设置的数据库账号密码未将本地改为线上,导致数据库连接多次而报错,另外navicat进到该IP的线上库也报错1129,报错信息 Host’123.45.678.99’ is blocked because of many connection errors; unblock with 'mysqladmin flush-hosts’ 。如下图:
网上百度了一大圈找到原因:
由于MYSQL数据库的参数:max_connect_errors(系统默认10),mysqld已经得到了大量(max_connect_errors)的主机“hostname”,因为在中途被中断了的连接请求累计超过10次,就再也无法连接上mysqld服务,同一个ip在短时间内产生太多中断的数据库连接而导致的阻塞(超过mysql数据库max_connection_errors的最大值)。
解决方法:
1、修改max_connect_errors的值,可以改为1000,但是实践效果不理想,因为mysql配置文件已经是1000了,但是仍然报1129(治标不治本,不推荐)。
2、使用命令清除缓存(推荐)
// 命令行
mysqladmin -u root-p flush-hosts // 回车后输入密码
mysqladmin flush-hosts -u root-p**(也有这种写法)**
方法3
结果还是不行,跟运维同事商量了下,他提出有可能是我的网络ip被封冻了,因为公司内网WiFi是用账号登录访问的,建议我用VPN或插网线试下。最终问题成功解决!