问题:Docker compose端口映射,主机端口!u003d容器端口

如何使curl http://barfoo:8002从 foobar-container 工作,而不更改 docker 文件?

我有以下撰写文件:

version: '3'
services:
  foobar:
    build:
      context: ./foobar
    ports:
      - 8001:80
    depends_on:
      - barfoo
  barfoo:
    build:
      context: ./barfoo
    ports:
      - 8002:80

我将以下内容添加到计算机上的主机文件中

127.0.0.1     foobar
127.0.0.1     barfoo

现在我用docker-compose up开始这个项目。

当我在终端上执行以下操作时,这在逻辑上可以正常工作:curl http://barfoo:8002

当我从 foobar 容器(docker-compose exec foobar /bin/bash)中的 Bash 执行相同操作时,我得到Failed to connect to barfoo port 8002: Connection refused,如果我使用curl http://barfoo:80它可以工作。

原因是我想模拟类似生产的情况,在生产中不需要端口,因为它们使用不同的主机名,并且都可以直接使用端口 80

解答

如何让 curlhttp://barfoo:8002从 foobar-container 工作,而不更改 docker 文件?

简单的解决方案是将主机端口 8002 映射到barfoo端口 8002。但这可能不是您想要的。

barfoo是在内部 docker dns 中注册的服务名称,只能由运行docker-compose up时创建的同一 docker 网络中的服务 (foobar) 访问

8002 是映射到 docker 主机的端口。

因此,当您从foobar容器运行curl http://barfoo:8002时,您会尝试将服务barfoo连接到端口 8002。但是barfoo侦听容器内的端口 80 而不是 8002。

另一种解决方案:

您可以将network_mode: host添加到barfoofoobar中。

  foobar:
    build:
      context: ./foobar
    network_mode: host
    ports:
      - 8001:80
    depends_on:
      - barfoo
  barfoo:
    build:
      context: ./barfoo
    network_mode: host
    ports:
      - 8002:80

但是随后foobar需要使用localhost:8002进行连接

原因是我想模拟类似生产的情况,在生产中不需要端口,因为它们使用不同的主机名,并且都可以直接使用端口 80

如果这真的是你想要的,一个更好的选择是使用 docker stack。

您的服务将是docker swarm服务:

您可以使用以下方式部署它们:

docker deploy --compose-file path_to_compose_file

然后foobar将使用服务名称和端口barfoo:80连接到barfoo

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐