打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
Ubuntu Linux中开启MySQL远程访问功能的方法

为了给服务器一个真实的运行环境,今天在内网中部署了一台UbuntuLinux服务器,其中最头疼的就是MySQL的安装,apt下载更新的速度太慢了,于是就自行编译了一下MySQL的源码,具体的编译方法可以参考网上的一些资料吧,这里只对如何开始MySQL的远程访问功能做个简单的讲述:

1)确认一下3306是否对外开放,MySQL默认状态下是不开放对外访问功能的。查看的办法如下:

~# netstat -an | grep 3306

tcp 0 0 127.0.0.1:3306 0.0.0.0:* LISTEN

从上面可以看出,mysql3306端口只是监听本地的连接,这样就阻碍了外部IP对该数据库的访问,修改的办法其实很简单,进入到mysql的配置文件所在目录(/etc/mysql/my.cnf)下,找到文件中的如下内容:

# Instead of skip-networking the default is now to listen only on

# localhost which is more compatible and is not less secure.

bind-address = 127.0.0.1

bind-address注释掉,或者改成你想要使用的客户端主机IP

这样mysql的远程访问端口就算开启了,下面还有一个更重要的步骤,就是要给远程用户授权。

2)确认客户端用户是否具有访问权限。

为了让访问mysql的客户端的用户有访问权限,我们可以通过如下方式为用户进行授权:

mysql> grant all on *.* to user_name@’%’ identified by ‘user_password’;

上面的命令授予的用户权限可以访问mysql中的任意数据库(database)和表(table)

完成上面的两个步骤,重启mysql即可在远程登陆mysql服务器了。Mysql的重启命令如下:

sudo /etc/init.d/mysql restart

上面只是简单的一些介绍,不能包治百病,具体的情况还需要根据自己的运行环境来定,希望对大家有所帮助。

最近做Linux项目用到MySQL数据库,可是远程连接MySQL时总是报出erro 2003: Can’t connect to MySQL server on ’211.87.***.***’ (111),昨天查了好几个小时才找到解决方案,如下:

1.sudo gedit /etc/mysql/my.cnf

找到bind-address =127.0.0.1

修改为bind-address =0.0.0.0

2.sudo /etc/init.d/ mysql restart

在这种情况下如果再尝试远程连接,则会报出ERROR 1130 (HY000): Host ’211.87.***.***’is not allowed to connect to this MySQL server提示信息,不能远程连接数据库。

MySQL host上按如下命令操作

mysql -u root -ppassword //进入mysql控制台

mysql>use mysql;

mysql>update user set host = ‘%’ where user = ‘root’; //这个命令执行错误时可略过

mysql>flush privileges;

mysql>select host, user from user; //检查’%’ 是否插入到数据库中

mysql>quit

设置完成。

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
wdcp教程之如何在wdcp设置mysql的远程连接
允许ubuntu下mysql远程连接
ubuntu mysql新增用户并开启远程连接
寝室远程连接室友mysql数据库
mysql远程连接错误10038
Ubuntu下远程访问MySQL数据库
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服