Navicat连接MySQL 报错 1129

启动本地项目时,由于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或插网线试下。最终问题成功解决!

Navicat连接MySQL报错10060通常是由于网络连接问题引起的。以下是可能的解决方法: 1.检查MySQL服务器是否正在运行,并确保已启用远程连接。 2.检查防火墙设置,确保MySQL端口(默认为3306)未被阻止。 3.检查网络连接,确保可以从客户端计算机ping通MySQL服务器。 4.尝试使用IP地址而不是主机名连接MySQL服务器。 5.尝试使用SSH隧道连接MySQL服务器。 以下是一个使用SSH隧道连接MySQL服务器的示例代码: ```python import paramiko import pymysql # SSH连接信息 ssh_host = 'ssh_host' ssh_port = 22 ssh_user = 'ssh_user' ssh_password = 'ssh_password' # MySQL连接信息 mysql_host = 'mysql_host' mysql_port = 3306 mysql_user = 'mysql_user' mysql_password = 'mysql_password' mysql_db = 'mysql_db' # 创建SSH客户端 ssh_client = paramiko.SSHClient() ssh_client.set_missing_host_key_policy(paramiko.AutoAddPolicy()) ssh_client.connect(hostname=ssh_host, port=ssh_port, username=ssh_user, password=ssh_password) # 创建SSH隧道 ssh_tunnel = ssh_client.get_transport().open_channel('direct-tcpip', (mysql_host, mysql_port), ('localhost', 0)) # 创建MySQL连接 mysql_conn = pymysql.connect(host='127.0.0.1', port=ssh_tunnel.local_bind_port, user=mysql_user, password=mysql_password, db=mysql_db) # 执行SQL查询 with mysql_conn.cursor() as cursor: cursor.execute('SELECT * FROM table') result = cursor.fetchall() print(result) # 关闭MySQL连接和SSH客户端 mysql_conn.close() ssh_client.close() ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值