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远程链接的最佳方法,有能力的话请查看官方文档