在阿里云服务器上安装了Mysql数据库,在阿里云上使用一切正常。我用navicat 去连接服务器时显示Host is not allowed to connect to this MySQL server。
看见这个错误,第一反应是是不是阿里云服务器防火墙没有配置mysq的出入站规则。去阿里云检查了一下发现并不是这个原因。然后就去网上找资料。
这个错误,其实就是我们的MySQL不允许远程登录,所以远程登录失败了,解决方法如下:
-
在装有MySQL的机器上登录
MySQL mysql -u root -p密码
-
执行
use mysql;
-
执行
update user set host = '%' where user = 'root';
-
执行
FLUSH PRIVILEGES;
-
经过上面4步,就可以解决这个问题了。
最后:
在数据库中查询:select user,host from user ;
修改以后的root 账号的host 是% ,而其他的账号则为localhost 。我们可以看出host的作用是限制ip地址登录。localhost 是仅为本地登录。%为通配符,可以使任意ip地址进行登录访问。
在找资料的时候看见的,觉得以后可能会看,就先放在这里了。