解决 ERROR 1130 (HY000): Host is not allowed to connect to this MySQL server

当使用 MySQL 时,您可能会遇到错误信息"ERROR 1130 (HY000): Host 'hostname'is not allowed to connect to this MySQL server"这是 MySQL 用于防止未经授权的访问的标准安全特性。实际上,服务器还没有配置为接受来自相关主机的连接。

Common Causes:

(1) Connection Restrictions

MySQL 默认配置为只允许来自本地主机 (127.0.0.1) 的连接。

(2) User Privileges

用户可能没有从特定主机或任意主机进行连接的权限。

(3) Firewall Restrictions

防火墙可能会阻塞必要的端口 (MySQL 的 3306 端口)

(4) Incorrect bind-address

my.cnf 或 my.ini 文件有一个 bind-address 指令,该指令被设置为与您正在连接的 IP 不同的 IP。

Steps to Resolve the Error:

1. Connect to the MySQL Server

首先,您需要本地连接到 MySQL 服务器,或者使用不会抛出此错误的方法。

复制代码
mysql -u root -p

2. Grant Access to Your IP Address

如果只允许从特定 IP 地址连接

sql 复制代码
GRANT ALL PRIVILEGES ON *.* TO 'username'@'your_ip_address' IDENTIFIED BY 'password';

如果允许从任何 IP 连接 (不太安全)

sql 复制代码
GRANT ALL PRIVILEGES ON *.* TO 'username'@'%' IDENTIFIED BY 'password';

授予特权之后,刷新权限

sql 复制代码
FLUSH PRIVILEGES;

3. Check the Bind-Address

找到 mysqld.cnf(linux/unix)或 my.ini(Windows)文件。

查找 bind-address 指令,设置为 0.0.0.0,表示 MySQL 接受来任意主机的连接。

ini 复制代码
bind-address = 0.0.0.0

修改完成后,重新启动 MySQL 服务器。

复制代码
sudo systemctl restart mysql

4. Check Your Firewall

如果运行 MySQL 的机器上开启了防火墙,则可能会阻止外部连接,请确保放行 3306 端口。

复制代码
sudo ufw allow 3306/tcp 
sudo ufw reload

5. Test the Connection

从远程计算机再次尝试连接

复制代码
mysql -u username -p -h mysql_server_ip

我的开源项目

相关推荐
JZC_xiaozhong12 小时前
电商ERP如何同步订单数据到MySQL?集成方案解析
数据库·mysql·数据分析·etl工程师·嵌入式实时数据库·电商erp集成·数据集成与应用集成
-大头.14 小时前
Docker实战:构建高性能MySQL主从复制集群(读写分离)
mysql·docker·容器
burning_maple14 小时前
mysql数据库笔记
数据库·笔记·mysql
周某人姓周15 小时前
sqlilabs靶场通关详解
数据库·mysql·安全·网络安全
霖霖总总16 小时前
[小技巧41]InnoDB 如何判断一行数据是否可见?MVCC 可见性机制深度解析
数据库·mysql
Mr.徐大人ゞ18 小时前
生产可用的 MySQL8 一键安装脚本和一键巡检脚本
mysql
星梦清河18 小时前
MySQL—分组函数
数据库·mysql
霖霖总总19 小时前
[小技巧33]MySQL 事务持久化的一致性保障:binlog 与 redo log 的两阶段提交机制解析
数据库·mysql
消失的旧时光-19431 天前
第五课:数据库不是存数据那么简单 —— MySQL 与索引的后端视角
数据库·mysql
nice_lcj5201 天前
MySQL中GROUP_CONCAT函数详解 | 按日期分组拼接销售产品经典案例
数据库·mysql