欢迎来到代码驿站!

当前位置:首页 >

docker 突然不能被外网访问的解决方案

时间:2022-10-24 08:52:11|栏目:|点击:

根据大佬们的方法,找到了原因 sysctl net.ipv4.ip_forward. 腾讯云提示修复漏洞,执行完他们的脚本, ip转发就被关掉了。

后来研究了一下,可以通过 docker info 找到问题所在。

并且可以查看到docker给出一警告

解决方法:

sudo vim /etc/sysctl.conf 修改 ,保存 , 然后 systemctl restart network

或者

sysctl -w net.ipv4.ip_forward=1

但是这样处理可能服务器重启以后就失效了?

还有两个警告,一起处理一下就好了。

WARNING: bridge-nf-call-iptables is disabled
WARNING: bridge-nf-call-ip6tables is disabled

补充:docker网络问题,在docker容器内无法ping通宿主机的外网ip,可以ping通其他机器的外网ip

问题说明

机器A和机器B 都各自有自己的内网IP和外网IP,例如:A-IP-内、A-IP-外

B-IP-内、B-IP-外,A机器有一个域名www.xxx.com

在A机器上安装jenkins的docker容器,启动后,进入容器

#docker exec -it jenkins /bin/sh
然后在容器内 ping宿主机A的内网IP,可以ping通
#ping A-IP-内(172.16…) //返回可以ping通
#ping A-IP-外(202.106…) //ping不通
#ping www.xxx.com //可以被正确解析为A机的外网IP,但ping不通
#ping baidu.com //可以ping通

另外:

1.在docker容器外的宿主机A机 ping A-IP-外(202.106…)是通的。

2.在B机器上安装jenkins容器,在容器内ping A-IP-外(202.106…) 是通的。

2.在B机器上安装jenkins容器,在容器内ping B-IP-外(202.106…) 是不通的。

查找各类网络问题,删除容器、镜像、重装docker都不起作用。

总之:在docker容器内ping宿主机本身的公网IP怎么也ping不同

我需要在A机的容器内 ping www.xxx.com 内被解析为A机器的内网地址。

因为容器内可以ping通A机的内网地址。

新修改docker-compose文件

extra_hosts:
- " www.xxx.com:172.16.xxx.A"

重建docker容器后,进入docker容器

#ping A-IP-外(202.106…) //正确ping通,OK满足要求

上一篇:关于为Windows Service 2019 使用 Docker的问题

栏    目:

下一篇:Rainbond应用分享与发布官方文档说明

本文标题:docker 突然不能被外网访问的解决方案

本文地址:http://www.codeinn.net/misctech/217173.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有