Docker 的两个 Container,无法通过 [主机 ip:port] 互相 curl

272 天前
 KratosOmega

我的 Docker 有两个运行中的 Container 容器:

  1. Jenkins:
    • ip:192.168.0.220:10240
    • 名称:myjenkins
  2. Gitlab:
    • ip:192.168.0.220:10082
    • 名称:mygitlab

(主机 ip 为:192.168.0.220)

经过一次 [公司的网络改造] 后,发现这两个容器无法通过 [主机 ip:port ] 的方式 curl ,但是可以 ping 得通。以下为一些表现,求大家帮忙找找问题。(注:网络改造前,完全是可以通过 [主机 ip:port ] 互相访问的)。

在 jenkins 容器上:

  1. ping gitlab ip: ping 192.168.0.220:10082。没有问题。
  2. curl gitlab ip: curl 192.168.0.220:10082。一直没反应。
  3. curl gitlab 容器名称+port:curl http://mygitlab:3000。没有问题。(由于 gitlab 与 Jenkins 容器处于同一个 bridge network 当中,所以可以通过容器名称访问。其中 3000 为 gitlab 自身的端口号)

在主机上:

  1. ping gitlab ip: ping 192.168.0.220:10082。没有问题。
  2. curl gitlab ip: curl 192.168.0.220:10082。没有问题。

麻烦大家帮忙看看,为什么这两个容器没法通过 [主机 ip:port ] 互相 curl ?

3327 次点击
所在节点    程序员
30 条回复
whileFalse
272 天前
ping 还能带端口呢?
winterpotato
272 天前
1. 假设你的容器网络为 bridge network ,那么容器之间要 link,才能互相通过对方的 hostname 访问(你也提到了这点)
2. bridge network 情况下,需要通过 -p 发布端口到宿主机的某个接口,宿主机外面才能访问
3. bridge network 下,容器如果想要访问宿主机(的某个服务),那么一般会选择 docker0 也就是 172.17.0.1 ,当然选择 host 的某个网卡 IP 也行,只是不那么靠谱因为可能会变。
4. ping 没有端口的啦


根据你的现象总结,可能需要检查下
1. publish port 的写法以及 host 的 IP
2. 是否新增 iptables 规则,docker 是靠的 iptables
DefoliationM
272 天前
ping 是 icmp ,http 是 tcp ,完全两个东西,并不能说明一个行则另一个必须行。
KratosOmega
272 天前
@whileFalse #1 不知道啊,计算机网络不怎么懂
KratosOmega
272 天前
@winterpotato #2 感谢大佬。
但是,我们公司 [网络改造] 之前,jenkins 容器是完全可以通过 [主机 ip:port] 的方式访问 gitlab 的,现在确不行了。

-p 规则检查过了,现在宿主机外面访问完全没问题了。比如:宿主机外 192.168.0.220:10082 是完全可以访问 gitlab 的。

我周一去检查一下 iptables 规则。
KratosOmega
272 天前
@DefoliationM #3 那 http 不行怎么办呢?我们 [网络改造] 前,是完全行的。
wheat0r
271 天前
简单了解一下 tcp/ip 模型,然后了解一下 docker 的网络,你就知道了。
不解释的情况下,请使用容器名互访。
icaolei
271 天前
我有类似问题,不过是两台机器上,A 机器宿主机本身是可以 curl 到 B 机器的,但在 A 机器的一个容器里,只能 ping 通 B 机器的 IP ,curl 就不通,很奇怪,排查了很多地方都还没找到原因。有哪位大佬能提供一点线索吗?
hawhaw
271 天前
这些问题你把宿主机、容器的路由表和 iptables 规则都捋一遍,如果还有问题再来问更合适
Goooooos
271 天前
一般来说 tcping 才带端口
A01514035
271 天前
@icaolei 我觉得问题大概率出在 iptables 里。
INTOX8O
271 天前
两个容器加到一个 docker network 里面用容器名访问
KratosOmega
271 天前
@wheat0r #7 就是容器名互访不好用。比如 gitlab 中的仓库,maven 地址是 [主机 ip:port] 的,拉到 jenkins 里就没法拉到 maven 仓库了。
KratosOmega
271 天前
@icaolei #8 是不是要使用 overlay 网络啊你
pendulum
271 天前
ping 端口是什么操作?
wheat0r
271 天前
@KratosOmega #13 可是容器名和用哪个仓库没一毛钱关系。
我还是建议你稍微了解一点网络。
另外,这个问题可能跟网络改造也没什么关系
KratosOmega
271 天前
@wheat0r 就是比如我有一个 java 仓库,引用的 maven 仓库也是 gitlab 容器上的,maven 服务器地址和 gitlab 一样,也是 192.168.0.220:10082 。
这时候如果 jenkins 容器把这个 java 仓库拉一下编译,由于 jenkins 没法访问 192.168.0.220:10082 ,就没法下载引用的 maven 库,就没法编译
fish3125
271 天前
- 从 Docker 1.10 版本开始,docker daemon 实现了一个内嵌的 DNS server ,使容器可以直接通过“容器名”通信。使用默认的 bridge 网络,不能通过 DNS server 实现通过容器名通信。
- ping 通 192.168.0.220 是宿主机,和容器没有半点关系。根据网络,一般使用 bridge ,192.168.0.220:10082 这种是需要创建容器的时候把端口从容器里映射出来.
fish3125
271 天前
要用容器名通讯你必须创建一个 bridge 网络。
你得把创建容器的 docker run 命令,或者把 yaml 配置文件贴出来。
yinmin
271 天前
docker 主机的防火墙开放 tcp 端口。docker 有时候很奇怪,不开防火墙端口,外部机器能访问,但是内部容器可能会无法访问。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/1026187

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX