Workbench连接不上阿里云服务器的Mysql【详细方案,亲测有效】

这两天为了解决workbench连接不上阿里云服务器的问题,搞得头大,网上搜到的教程都大同小异,但唯独到我这就是行不通。不过好在最后终于解决了,记录一下这个坑爹的过程。

使用的环境:

  • 系统:Ubuntu 18.04.2 LTS
  • Mysql:mysql Ver 14.14 Distrib 5.7.29, for Linux (x86_64) using EditLine wrapper
  • MySQL Workbench8.0CE

1. 无法连接到服务器

一开始连接的时候是出现下面这种状态。

Workbench连接不上阿里云服务器的Mysql【详细方案,亲测有效】_第1张图片
遇到的坑之一

网上查到的大多数方法就是修改bind_address的值

先检查以下mysql的端口状态

netstat -anp|grep mysql

ps:如果显示127.0.0.1:3306 则说明需要修改,若为: : :3306,则不用

因为我显示的状态是127.0.0.1:3306是这个值,所以得去修改。

网上查到的大多数修改配置文件路径均说是在**/etc/mysql/my.cnf**,但这是对旧版本而已,由于我装的是最新版,所以打开这个文件之后发现里面并没有bind_address这个给值。后来查了一下才发现,新版的是在**/etc/mysql/mysql.conf.d/mysqld.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

2. 修改mysql.user表的信息

为了能让root用户远程访问数据库,所以得去改一些信息。

mysql -u root -p password
mysql>use mysql
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed
mysql> select user,host from user;
+------------------+----------------+
| user             | host           |
+------------------+----------------+
| root             | localhost              |
| debian-sys-maint | localhost      |
| mysql.session    | localhost      |
| mysql.sys        | localhost      |
+------------------+----------------+

上面的host表示用户可以从那些地址访问数据库。由于是localhost,所以只能本地访问。一共查到了两种修改方法,一个是直接将原本root对应的host改成**%**,或者新添一个可以远程访问的用户 。

方法一:

在进入mysql数据库中的状态下执行下面命令

update user set host='%' where user='root'

方法二:新添一个用户:

grant all privileges  on *.* to new_user@'%' identified by "password";

无论用了上面哪一种最后都得刷新一下刚才的设置

mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)

这两个方式都试了,还是不行,出现说我们目前的ip不允许连接。

Workbench连接不上阿里云服务器的Mysql【详细方案,亲测有效】_第2张图片
后来试了好多次发现, 远程连接的用户名不要用root。经过几次重装尝试发现,设置root可以远程连接,就一直失败。

3. 关闭防火墙

# 先重启一下数据库
sudo service mysql restart
# 检查MySQL端口状况是否为 : : :3306
netstat -anp|grep mysql
# 关闭防火墙
sudo ufw disable 
# 查看防火墙状态
sudo ufw status

4. 开放端口

阿里云或者其他云服务的用户一定要注意去开防对应的端口,默认状态mysql的端口为3306。

5. 搞定

Workbench连接不上阿里云服务器的Mysql【详细方案,亲测有效】_第3张图片

你可能感兴趣的:(学习笔记)