错误信息
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进行刷新权限操作。
版权声明:本文为原创文章,版权归 阁主 所有,欢迎分享本文,转载请保留出处!
免责申明:有些内容源于网络,没能联系到作者。如侵犯到你的权益请告知,我们会尽快删除相关内容。
黔ICP备19006353号-2
贵公网安备 52052102000042号