docker - 如何与另一个主机Y中的主机X中正在运行的Docker容器通信(而不是与主机Y中的容器通信)

标签 docker docker-compose docker-swarm docker-machine

我正在试验Docker网络,我设置了以下方案,
将docker安装在通过网络连接的host-X(host-X IP:60.0.0.28)中,并运行ubuntu-OS的基本docker容器(Docker容器仅连接到默认docker bridge网络,即172.17.0.0/16& 172.17.0.2是容器IP)。现在尝试与另一个未安装docker的网络(主机-Y IP:60.0.0.40)中的另一个主机-Y交流该正在运行的容器。
我在host-Y中添加了基本路由,例如“ip route通过60.0.0.28 dev ens3添加172.17.0.0/16”。
从容器中,我能够ping通Host-Y,反之,我只能从Host-Y ping docker网关“172.17.0.1”,但无法访问容器。

最佳答案

在很多情况下,Docker内部IP地址都没有用。来自其他主机的 call 就是其中之一。您应该完全忽略这些作为实现细节。
如果您将Docker移出图片,并直接在主机上运行该过程,这应该很简单:从主机Y,您可以在主机X上调用给定DNS名称和服务器正在运行的端口的进程。

hostY$ curl http://hostX:12345/
如果该进程实际上在Docker容器中运行,则需要确保已使用已发布的端口启动了该容器。这不一定需要匹配进程正在侦听的端口。
hostX$ docker run -p 12345:12345 imagename
完成此操作后,就可以通过主机的DNS名称或IP地址以及发布的端口(与非容器服务器相同的方式)来完成此过程。
在正常情况下,您无需考虑Docker内部的IP地址。您不需要像显示的那样手动进行ip路由设置命令,也不需要docker inspectdocker run --ip来查找或设置此详细信息。

关于docker - 如何与另一个主机Y中的主机X中正在运行的Docker容器通信(而不是与主机Y中的容器通信),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63618760/

相关文章:

docker - 如何对Docker进行逆向工程?

docker - docker全局服务和复制之间有什么区别,以及如何更改全局服务的数量?

docker - 如何在 docker swarm 中重新启动多个容器

linux - Docker,AWS-EKS : Docker-build command, Davfs 挂载不工作,没有免费的 coda 设备可以挂载

docker 中的 php Curl 冲突 CURLOPT_FILE 和 CURLOPT_RETURNTRANSFER

django - Pytest 不能与 Django 和 Docker 一起使用 - AssertionError : local ('/dev/console' ) is not a file

docker - 在容器名称上使用 glob/通配符运行 docker 命令

Docker 中的 Python 日志记录

docker - 像卷一样将绑定(bind)挂载添加到 Dockerfile

docker - 连接两个 docker 容器