使用 Navicat 进行远程连接,连接 MySQL 前需要防火墙(firewall) 开发端口,或者关闭防火墙。
开放端口:
# 3306 表示开放的端口号 --permanent 永久生效,没有此参数重启后失效
firewall-cmd --add-port=3306/tcp --permanent
# 重新载入
firewall-cmd --reload
关闭防火墙:
# 关闭防火墙
systemctl stop firewalld
# 设置开机启动
systemctl enable iptables
# 重新载入
firewall-cmd --reload
防火墙(firewalld) 的基本使用
# 启动
systemctl start firewalld
# 关闭
systemctl stop firewalld
# 查看状态
systemctl status firewalld
# 开机禁用
systemctl disable firewalld
# 开机启用
systemctl enable firewalld
如果到目前为止还是无法通过 Navicat 连接上mysql,并且选择使用的是 mysql 8.0
那么请尝试以下配置:
mysql 8.0
默认使用的是 caching_sha2_password
身份验证机制,客户端不支持新的加密方式。
解决方案:
进入 mysql 容器,登录 mysql 查看权限,并修改。
# master 表示容器中 mysql 的 name ,也可以使用容器 id
[root@localhost ~]# docker exec -it master bash
# 登录 mysql
root@bd15a018a99f:/# mysql -u root -p
# 查看用户信息
mysql> select host,user,plugin,authentication_string from mysql.user;
信息结果如下:
其中,host 为 “%” 表示不限制 ip 。
修改加密方式:
# 123456 表示 mysql 登录密码
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';
# 重新加载权限表
flush privileges;
再次查看用户信息是否已经修改完成。
在尝试使用 Navicat 进行连接 mysql 。