“flush-host 不生效”可能由多种原因导致,以下是一些可能的解决方法:
1. 检查 `max_connect_errors` 值:`max_connect_errors` 是一个与安全有关的计数器,它负责阻止过多尝试失败的客户端以防止暴力破解密码等情况。当同一个 IP 在短时间内产生太多(超过 `max_connect_errors` 的最大值)中断的数据库连接时,MySQL 会拒绝该客户端的新连接。 首先,使用 root 用户登录 MySQL 数据库,执行以下命令查看 `max_connect_errors` 的值:
show variables like '%max_connect_errors%';
如果该值较小,可以考虑增大它。 - 临时修改(重启后失效):
set global max_connect_errors = 1000;
- 永久修改(需重启 MySQL 服务生效):在 MySQL 的配置文件(如
/etc/my.cnf
或C:\ProgramData\MySQL\MySQL Server 8.0\my.ini
)中添加或修改以下行:
max_connect_errors = 1000
然后重启 MySQL 服务。
2. 正确执行 `flush-hosts` 命令: - 方法
1:使用命令行执行,找到 `mysqladmin` 所在的目录(如果不知道位置,可以使用命令查找:`which mysqladmin`),然后执行以下命令,其中服务器 IP 地址、端口号、用户名、密码等参数都可以根据实际情况进行修改:
/usr/bin/mysqladmin flush-hosts -h123.57.78.101 -p3306 -uroot -p123456
- 方法 2:直接在数据库中执行以下命令:
flush hosts;
3. 重启 MySQL 服务:
有时候,简单的重启也可能解决问题。重启方法如下:
- Linux 系统:使用管理员权限执行
`sudo systemctl restart mysql` 或 `/etc/init.d/mysqld restart` 命令。
- Windows 系统:在服务管理器中找到 MySQL 服务并进行重启。
“flush hosts” 只在低于8.0版本一下的mysql中有效
高于版本
使用替代命令清理 host_cache
:使用管理员权限登录 MySQL 数据库,执行以下命令来清理 performance_schema.host_cache
表:
TRUNCATE TABLE performance_schema.host_cache;