Navicat连接MySQL数据库提示:1130 - Host 'xxx' is not allowed to connect to this MySQL server

原创 阁主  2026-03-15 04:36:49  阅读 1661 次 评论 0 条
摘要:

在局域网搭建了一台MySQL服务器,但是在使用笔记本无法连接上,错误信息和解决方法在正文。

错误信息

Navicat连接提示:1130 - Host ‘xxx’ is not allowed to connect to this MySQL server

错误原因

mysql未开启mysql远程访问权限导致。

解决方法

登录到mysql: mysql -uroot -proot
查看user表

# 使用数据库mysql
use mysql;
# 查看主机和用户
select host, user from user;


表中host、user字段标识了可以访问数据库的主机和用户。例如上面的数据就表示只能本地主机通过root用户访问。为了让数据库支持远程主机访问,有两种方法可以开启远程访问功能,这里建议使用第一种
第一种(改表法):
修改host字段的值,将localhost修改成需要远程连接数据库的ip地址。或者直接修改成%。(修改成%表示,所有主机都可以通过root用户访问数据库)这里就直接修改成%。命令如下:
update user set host = '%' where user = 'root';
再次查看user表, 修改成功,重启数据库或者输入命令FLUSH PRIVILEGES(重新加载权限表);测试再次远程连接数据库成功。

第二种(授权法):
root使用密码root从任何主机连接到mysql服务器,命令如下:
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root' WITH GRANT OPTION;
允许用户user从ip为192.168.1.30的主机连接到mysql服务器,并使用user作为密码:
GRANT ALL PRIVILEGES ON *.* TO 'root'@'192.168.1.30' IDENTIFIED BY 'mypassword' WITH GRANT OPTION;
重启数据库或者输入命令FLUSH PRIVILEGES(重新加载权限表)

注意:

记得执行修改记录后需要使用命令:FLUSH PRIVILEGES进行刷新权限操作。

本文地址:https://www.mainblog.cn/289.html
版权声明:本文为原创文章,版权归 阁主 所有,欢迎分享本文,转载请保留出处!
免责申明:有些内容源于网络,没能联系到作者。如侵犯到你的权益请告知,我们会尽快删除相关内容。
NEXT:已经是最新一篇了

评论已关闭!