解决Docker部署mysql远程连接 解决2003的问题

使用 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;

信息结果如下:
image-20210718104825475
其中,host 为 “%” 表示不限制 ip 。

修改加密方式:

# 123456 表示 mysql 登录密码
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';
# 重新加载权限表
flush privileges;

再次查看用户信息是否已经修改完成。

在尝试使用 Navicat 进行连接 mysql 。
在这里插入图片描述

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值