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

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

问题背景

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

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

博主用的是腾讯云服务器,在服务器安全组里也开放了3308端口
mysql也授权了远程连接
至此可在本地电脑远程连接mysql

=就这样过了一年多

发现问题

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

排查问题

于是进行排查
首先看3308端口是否在腾讯云后台安全组放行
在这里插入图片描述
如上图,入站规则是全部放行的

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

[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像下面这样
在这里插入图片描述
那么我们再来执行一下下面的命令

[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区域端口

[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无法远程连接。
  • 5
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 要让CentOS 7上的Docker安装MySQL可以远程连接,需要进行以下步骤: 1. 首先,确保CentOS 7上已经安装DockerDocker Compose。可以通过运行以下命令来检查它们的版本: ``` docker version docker-compose version ``` 2. 下载MySQLDocker镜像并生成一个新的容器。可以运行以下命令来完成此步骤: ``` docker run -d --name mysql -e MYSQL_ROOT_PASSWORD=your_password -p 3306:3306 mysql:latest ``` 3. 在此步骤中,注意将`your_password`替换为您自己设置的密码。此命令会创建一个名为`mysql`的容器,并将MySQL的默认端口3306映射到主机的3306端口。 4. 检查Docker容器是否正在运行,并且3306端口是否已被监听。可以使用以下命令来检查它们: ``` docker ps netstat -tuln | grep 3306 ``` 5. 确保CentOS 7防火墙已正确配置以允许从远程访问MySQL的3306端口。可以使用以下命令来打开3306端口: ``` firewall-cmd --zone=public --add-port=3306/tcp --permanent firewall-cmd --reload ``` 6. 现在,可以从远程机器使用MySQL客户端连接到CentOS 7上的Docker中运行的MySQL实例。使用以下命令连接到MySQL服务器: ``` mysql -u root -p -h your_server_ip ``` 请注意将`your_server_ip`替换为CentOS 7主机的IP地址,将提示输入密码即可。 通过执行以上步骤,您应该能够远程连接到CentOS 7上运行的Docker MySQL实例。 ### 回答2: 当在CentOS 7上使用Docker安装MySQL时,可能会遇到无法远程连接的问题。以下是一些可能的解决方法: 1. 检查Docker容器网络设置:确认Docker容器是否使用正确的网络模式。可以使用`docker ps`命令查看容器的详细信息,确认容器是否使用了`--network`参数或正确的`network_mode`设置。 2. 检查MySQL配置文件:在Docker容器内部,打开MySQL配置文件`/etc/mysql/my.cnf`,确保`bind-address`设置为`0.0.0.0`,允许所有IP访问数据库。 3. 检查容器端口映射:通过`docker ps`命令查看MySQL容器的端口映射情况,确保将MySQL容器的端口映射到正确的主机端口上。例如,如果容器内部的MySQL端口是3306,则可以通过`docker run`命令的`-p`参数将其映射到主机上的端口。 4. 防火墙配置:如果在主机上启用了防火墙,可能需要打开MySQL所用的端口。可以使用以下命令将3306端口添加到防火墙规则中: ``` sudo firewall-cmd --zone=public --add-port=3306/tcp --permanent sudo firewall-cmd --reload ``` 5. 检查MySQL用户权限:确保在MySQL容器中,用户拥有远程连接MySQL的权限。可以通过以下命令登录MySQL容器: ``` docker exec -it <mysql_container_id> bash mysql -u root -p ``` 然后在MySQL命令行中,执行以下命令检查用户权限: ``` SHOW GRANTS FOR '<username>'@'%' ; ``` 如果没有远程连接权限,可以通过以下命令为该用户添加权限: ``` GRANT ALL PRIVILEGES ON *.* TO '<username>'@'%' IDENTIFIED BY '<password>' WITH GRANT OPTION; FLUSH PRIVILEGES; ``` 6. 检查主机网络连接:确保从远程主机可以ping通CentOS 7主机的IP地址。如果ping不通,可能是网络配置的问题,需要检查网络设置和路由。 希望以上解决方法能够帮助你解决无法远程连接的问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大叔是90后大叔

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值