远程链接ubuntu-server的MySQL8.0

1.首先设置MySQL8.0允许远程链接

mysql> use mysql;

1.1 修改访问权限

mysql> select host,user,plugin from user;

在这里插入图片描述
1.2 将访问权限修改成 “%”, 代表允许任何主机通过root账号远程访问

mysql> update user set host='%' where user ='root';

1.3 更新权限设置

mysql> FLUSH PRIVILEGES;

1.4 非root用户执行下面语句(MySQL8.0以后需要先创建用户才能执行授权操作)

mysql> ceare user 'your_username'@'%';
mysql> GRANT ALL PRIVILEGES ON *.* TO 'your_username'@'%'WITH GRANT OPTION;

2 开放3306端口
查看远程主机3306端口是否开放

netstat -ntlp|grep 3306

如果无显示代表没有开放3306端口
需要执行:

sudo ufw enable  # 开启防火墙
sudo ufw default deny # 默认关闭所有外部访问
sudo ufw allow 3306  # 打开3306端口

或者

sudo ufw allow IP地址   # 指定允许某主机访问所有端口

如果需要关闭端口或者删除IP访问

sudo ufw  delete allow 端口号/IP地址

然后检查防火墙设置。
ufw status一下看看有没有开启3306

最后,mysql默认是只允许本地连接的。所以我们需要修改一个配置文件。然而最新版本的mysql跟以前目录结构不太一样,最新版本的允许远程连接放在/etc/mysql/mysql.conf.d/mysqld.cnf 这个配置文件下,搜索bind-address = 127.0.0.1 这行,把它注释掉,然后是用命令service mysql restart重启mysql服务就可以了。

该方法并不是解决MySQL8.0远程链接的最佳方法,有能力的话请查看官方文档

发布了12 篇原创文章 · 获赞 1 · 访问量 1244

猜你喜欢

转载自blog.csdn.net/qq_36488647/article/details/100876201