docker安装mysql突然无法远程连接

docker安装mysql突然莫名其妙的无法远程连接

docker安装mysql突然无法远程访问

问题背景

大概一年前在服务器中通过docker安装mysql5.7端口映射关系是3308->3306

前期在服务器上开方了3308端口

bash 复制代码
firewall-cmd --zone=public --add-port=3308/tcp --permanent
firewall-cmd --reload   # 配置立即生效

博主用的是腾讯云服务器,在服务器安全组里也开放了3308端口

mysql也授权了远程连接

至此可在本地电脑远程连接mysql

=就这样过了一年多

发现问题

今天博主通过命令安装了宝塔,然后就发现docker安装的mysql无法连接了。。。。。。

排查问题

于是进行排查

首先看3308端口是否在腾讯云后台安全组放行

如上图,入站规则是全部放行的

再看服务器防火墙是否开放3308端口

bash 复制代码
[root@VM_0_2_centos ~]# firewall-cmd --query-port=3308/tcp
You're performing an operation over default zone ('public'),
but your connections/interfaces are in zone 'docker' (see --get-active-zones)
You most likely need to use --zone=docker option.

yes

发现3308端口也是放行的

执行telnet xx.xxx.xxx.xx 3308无法连接

至此就很莫名奇妙怎么会不通呢

很是郁闷。。。。。。

实在想不通 只好把服务器防火墙关了

再来用telnet测试3308端口居然能连上了,远程连接mysql也成功了

然后再开启服务器防火墙

再来用telnet测试3308端口结果无法连接上,远程连接mysql也失败了
至此可以断定问题一定出在防火墙上!

再来仔细看一下服务器开放端口查询返回的结果好像有点什么不一样

突然想起来以往查询端口返回的结果只有yes或者no像下面这样

那么我们再来执行一下下面的命令

bash 复制代码
[root@VM_0_2_centos ~]# firewall-cmd --query-port=3308/tcp --zone=docker
no

发现返回结果为no

到这里大致知道问题出在这了,通过翻译可以理解查询firewalld中关于TCP端口3308的状态默认是在 public 区域进行的而实际上TCP连接或接口被分配在了docker区域

通过查阅资料得知在firewalld中,不同的区域可以有不同的规则集,因此需要指定正确的区域来执行你的查询。
到此可得出docker区域的3308端口没有开放!

解决问题

执行命令放行docker区域端口

bash 复制代码
[root@VM_0_2_centos local]# firewall-cmd --zone=docker --add-port=3308/tcp --permanent
success
[root@VM_0_2_centos local]# firewall-cmd --reload
success

[root@VM_0_2_centos local]# firewall-cmd --query-port=3308/tcp --zone=docker
yes

docker区域端口放行成功后

再来用telnet测试3308端口可以连上并且远程连接mysql也成功了。

总结

复制代码
	问题出现的原因应该是安装宝塔的过程中升级了防火墙,新版本的防火墙执行的是更严格的规则导致docker安装的mysql无法远程连接。
相关推荐
heimeiyingwang4 分钟前
【架构实战】Kubernetes日志收集:EFK/Loki架构
容器·架构·kubernetes
SPC的存折1 小时前
D在 Alpine 容器中手动搭建 Discuz 全攻略(包含镜像一键部署脚本,可直接用)
linux·数据库·mysql·缓存
AgCl231 小时前
MYSQL-6-函数与约束-3/17
android·数据库·mysql
junqiduhang1 小时前
Win11 MySQL 8.0 安装八步走
数据库·mysql
SPC的存折3 小时前
6、Docker常用配置
运维·docker·容器
图图玩ai3 小时前
SSH 命令管理工具怎么选?从命令收藏到批量执行一次讲清
linux·nginx·docker·ai·程序员·ssh·可视化·gmssh·批量命令执行
小菜同学爱学习4 小时前
夯实基础!MySQL数据类型进阶、约束详解与报错排查
开发语言·数据库·sql·mysql
SPC的存折4 小时前
4、Docker私有仓库
运维·docker·容器
齐潇宇5 小时前
Docker概述与安装
linux·运维·docker·容器
小旭95276 小时前
MySql调优详解
数据库·mysql·数据库架构