解决方法:
- 改表法。可能是你的帐号不允许从远程登陆,只能在 localhost。这个时候只要在 localhost 的那台电脑,登入 mysql 后,更改 "mysql" 数据库里的 "user" 表里的 "host" 项,从"localhost"改称"%"
mysql>mysql -u root -p;
mysql>use mysql;
mysql>update user set host = '%' where user = 'root';
mysql>select host, user from user;
- 授权法。例如,你想 root 使用 mypassword 从任何主机连接到 mysql 服务器的话。
允许 root 用户在任何地方均可链接:
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'mypassword' WITH GRANT OPTION;
如果你想允许用户 root 从 ip 为特定 IP(如 192.168.1.3)的主机连接到 mysql 服务器,并使用 mypassword 作为密码
GRANT ALL PRIVILEGES ON *.* TO 'root'@'192.168.1.3' IDENTIFIED BY 'mypassword' WITH GRANT OPTION;
通过任意一种方式进行修改时,要重启 MySQL 服务,方能生效
文章首次发布于 吾勇士的博客 http://wuyongshi.top/articles/2017/05/13/1494679617739.html
借鉴文章:http://chen3888015.blog.51cto.com/2693016/986841
http://stackoverflow.com/questions/1559955/host-xxx-xx-xxx-xxx-is-not-allowed-to-connect-to-this-mysql-server
欢迎来到这里!
我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。
注册 关于