繁体   English   中英

从一个 Docker 容器内部,如何连接到同一 Docker 主机上另一个 Docker 容器的端口?

[英]From inside one Docker container, how to connect to the port of another Docker container on the same Docker host?

在 Ubuntu 20.04 上运行新的 Docker 20.10.1。 此版本包括对 Linux 上 dockerd 中的 host.docker.internal的支持

root@docker04:~# docker --version
Docker version 20.10.1, build 831ebea

我在使用 SSL 证书的容器中运行一堆服务,我想使用 Telegraf 检查证书是否过期(稍后发送到 Grafana 仪表板)。

所有具有 web 接口和 Telegraf 的服务都运行在同一个 Docker 主机上。 所有服务都在自己的桥接网络中。 我想在端口 9000 上Telegraf 连接Portainer(见下文)。

----------VM running docker (10.10.1.32)----------
|                                                |
|    --------------------                        |
|    | Gitea            |                        |     
|    | Ports: 3000:3000 |                        |
|    | Network: gitea   |                        |
|    --------------------                        |
|                                                |
|    ----------------------                      |
|    | Portainer          |                      |
|    | Ports: 9000:9000   |<--|                  |
|    | Network: portainer |   |                  |
|    ----------------------   |                  |
|                             |                  |
|    ---------------------    |                  |
|    | Telegraf          |    |                  |
|    | Network: telegraf |-->-                   |
|    |                   |                       |
|    ---------------------                       |
|                                                |
--------------------------------------------------

我认为有了对 host.docker.internal 的新支持,我可以从一个容器连接到另一个容器,但这似乎不起作用。 Ping 有效,但我无法连接到端口 9000。

root@docker04:~# docker run -it --add-host host.docker.internal:host-gateway alpine /bin/sh
/ # ping host.docker.internal
PING host.docker.internal (172.17.0.1): 56 data bytes
64 bytes from 172.17.0.1: seq=0 ttl=64 time=0.102 ms
64 bytes from 172.17.0.1: seq=1 ttl=64 time=0.100 ms
^C
/ # telnet host.docker.internal 9000
telnet: can't connect to remote host (172.17.0.1): Operation timed out

telnet 的最后一个命令挂起并最终断开连接。 我在这里错过了什么吗? 这仅适用于主机网络吗? 我显然误解了 Docker 网络在这里......

如果我也尝试使用主机的 IP,它也会失败。

/ # telnet 10.10.1.32 9000
telnet: can't connect to remote host (10.10.1.32): Operation timed out

尝试在同一网络上的所有容器或 map 在一个容器上的两个网络上运行,例如在具有 network1、network2 的 1 个容器上运行,为什么您会遇到此问题,因为您为每个容器使用不同的私有桥接网络。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM