解决 docker 容器无法通过 IP 访问宿主机问题

问题起源

在使用 docker 的过程中我不幸需要在 docker 容器中访问宿主机的 80 端口, 而这个 80 端口是另外一个容器 8080 端口映射出去的. 当我在容器里通过 docker 的网桥 172.17.0.1 访问宿主机时, 居然发现:

curl: (7) Failed to connect to 172.17.0.1 port 80: No route to host

查找问题原因

可以确定的是容器与宿主机是有网络连接的, 因为可以在容器内部通过 172.17.0.1 Ping 通宿主机:

 
  1. root@930d07576eef:/# ping 172.17.0.1

  2. PING 172.17.0.1 (172.17.0.1) 56(84) bytes of data.

  3. 64 bytes from 172.17.0.1: icmp_seq=1 ttl=64 time=0.130 ms

也可以在容器内部访问其它内网和外网.
iptables 显示也允许 docker 容器访问:

 
  1. # iptables --list | grep DOCKER

  2. DOCKER-ISOLATION all -- anywhere anywhere

  3. DOCKER all -- anywhere anywhere

  4. Chain DOCKER (1 references)

  5. Chain DOCKER-ISOLATION (1 references)

之后在查找一些资料后发现这个问题: NO ROUTE TO HOST network request from container to host-ip:port published from other container.

解释

正如 Docker Community Forms 所言, 这是一个已知的 Bug, 宿主机的 80 端口允许其它计算机访问, 但是不允许来自本机的 Docker 容器访问. 必须通过设置 firewalld 规则允许本机的 Docker 容器访问.
gypark 指出可以通过在 /etc/firewalld/zones/public.xml 中添加防火墙规则避免这个问题:

 
  1. <rule family="ipv4">

  2. <source address="172.17.0.0/16" />

  3. <accept />

  4. </rule>

注意这里的 172.17.0.0/16 可以匹配 172.17.xx.xx IP 段的所有 IP.
之后重启下防火墙:

systemctl restart firewalld

之后就可以在 docker 容器内部访问宿主机 80 端口.

其它问题

实际上当我又用 vmware 新开了一台虚拟机希望能重现这个问题的时候, 发现在新的虚拟机上居然没有类似的问题. 也就是说容器可以直接通过172.17.0.1访问宿主机 80 端口, 查看防火墙配置也没看到有172.17.xx.xx的白名单.
猜测是由于在新的虚拟机安装的 docker 是 Docker version 1.12.5, build 047e51b/1.12.5, 也就是 Red Hat 从 docker 开源版本迁出开发的版本, 而之前的是 Docker version 17.06.2-ce, build cec0b72 属于 Docker-CE, 可能是 docker 版本有差异, Red Hat 顺便把那个 Known Bug 修复了.

Docker容器无法通过IP地址访问宿主机时,一个常见的情况是由于网络配置不当或防火墙规则限制导致的。为了彻底解决这个问题,推荐详细阅读《详解如何解决docker容器无法通过IP访问宿主机问题》这份资料。该资料从问题的现象入手,逐步分析原因,并提供了一系列解决步骤。 参考资源链接:[详解如何解决docker容器无法通过IP访问宿主机问题](https://wenku.youkuaiyun.com/doc/6401acd8cce7214c316ed5b0?spm=1055.2569.3001.10343) 首先,需要确认Docker容器是否正确连接到了宿主机网络,并且宿主机的相关端口是否对外开放。可以通过在容器内部使用ping命令来测试网络连接。如果ping命令成功,说明网络层面是通的,问题可能出在端口转发或防火墙上。 其次,检查Docker容器是否在正确的网络模式下运行,比如host模式可能会有不同的网络访问行为。可以通过docker inspect命令查看容器的网络配置。 如果上述步骤确认无误,接下来应检查宿主机的防火墙设置,确保没有规则阻止了容器宿主机端口的访问。此外,还需要确认Docker的网络配置,比如桥接模式下是否设置了正确的网络参数。 在某些情况下,可能需要设置Docker服务的iptables规则,允许容器宿主机之间的通信。这可能涉及到对iptables进行修改,增加特定的转发规则。 此外,对于端口转发问题,需要检查Docker容器的端口映射配置是否正确。如果你的情况是宿主机端口映射到了另一个容器的端口,确保容器间的网络策略允许这种转发。 最后,根据问题的细节,使用《详解如何解决docker容器无法通过IP访问宿主机问题》中提供的解决方案,可以具体调整docker-compose.yml文件或Docker命令行参数,以适应你的具体情况。 通过上述步骤,你应该能够解决Docker容器无法通过IP访问宿主机问题。为了进一步深入理解和掌握容器网络相关知识,阅读完《详解如何解决docker容器无法通过IP访问宿主机问题》后,可以继续学习Docker官方文档或相关高级教程,以获得更全面的理解。 参考资源链接:[详解如何解决docker容器无法通过IP访问宿主机问题](https://wenku.youkuaiyun.com/doc/6401acd8cce7214c316ed5b0?spm=1055.2569.3001.10343)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值