建议使用以下浏览器,以获得最佳体验。 IE 9.0+以上版本 Chrome 31+ 谷歌浏览器 Firefox 30+ 火狐浏览器
请选择 进入手机版 | 继续访问电脑版
设置昵称

在此一键设置昵称,即可参与社区互动!

确定
我再想想
选择版块

高晓云

发帖: 33粉丝: 21

级别 : 管理员

Rank: 9Rank: 9Rank: 9

发消息 + 关注

发表于2018-11-1 09:46:29 4104 1 楼主 显示全部楼层
[MySQL] Mysql数据库无法远程连接的解决方法

在远程主机上,我开启了mysql 服务,用 phpmyadmin 可以打开,比如说用户名为 root,密码为 123456。不过用 Mysql 客户端远程连接时却报了错误,比如 Mysql-Front 报了如下错误。

Access denied for user ‘root’@’121.42.8.33′(using password:YES)

image.png

比较奇怪,phpmyadmin 可以正常访问,而 Mysql-Front 为什么无法连接呢?可能的原因,应该就是 IP 限制了,phpmyadmin在连接时使用的是localhost,而我们访问页面才使用的远程主机的 IP,而 Mysql-Front 连接的是远程主机。

解决方法如下,

首先修改mysql的配置文件,my.cnf,将

#bind-address = 127.0.0.1


这一行注释掉,要不然它永远限制了只能本机连接

然后我们需要新建一个用户,然后授予所有 IP 可以访问的权限就好啦。

在下面的 sql 语句中,username 即为用户名,password 为你要设置的密码。

CREATE USER 'username'@'localhost' IDENTIFIED BY 'password';
 
GRANT ALL PRIVILEGES ON *.* TO 'username'@'localhost' WITH GRANT OPTION;
 
CREATE USER 'username'@'%' IDENTIFIED BY 'password';
 
GRANT ALL PRIVILEGES ON *.* TO 'username'@'%' WITH GRANT OPTION;


通过执行以上语句,便创建了一个用户名为 username,密码为 password 的新账户,再用新账号登录,就可以连接成功啦。


举报
分享

分享文章到朋友圈

分享文章到微博

建赟

发帖: 225粉丝: 13

级别 : 版主

Rank: 7Rank: 7Rank: 7

发消息 + 关注

发表于2018-11-28 14:31:48 沙发 显示全部楼层

学习一下

点赞 回复 举报

游客

您需要登录后才可以回帖 登录 | 立即注册