无法链接到由docker-compose启动的正在运行的容器


99

我正在使用Docker容器设置本地开发环境。docker-compose.yml如下所示

version: '2'

services:
  db:
    image: mongo:3
  mq:
    image: rabbitmq:3
  api:
    build: .
    image: my_app/api
    ports:
      - "3000:3000"
    links:
      - db
      - mq
    environment:
      - NODE_ENV=development

它开始没有错误。码头工人列出了3个正在运行的容器

docker-compose up -d
docker ps

e90e5a8b5d33        my_app/api    "/usr/local/bin/node "   0.0.0.0:3000->3000/tcp               my_app_api_1
42bfcd971b16        mongo:3       "/entrypoint.sh mongo"   27017/tcp                            my_app_db_1
a0685a816c47        rabbitmq:3    "/docker-entrypoint.s"   4369/tcp, 5671-5672/tcp, 25672/tcp   my_app_mq_1

但是,当我尝试从另一个容器链接到那些正在运行的容器时

docker run --link my_app_mq_1:mq --link my_app_db_1:db -it worker 

我得到错误

 docker: Error response from daemon: Cannot link to /my_app_mq_1, as it does not belong to the default network.

我也尝试过

 docker run --link my_app_mq_1:mq --link my_app_db_1:db -it --net default worker 

同样的错误。

那么如何链接到由docker-compose启动的正在运行的容器?

Answers:


196

好的,找到答案了。万一其他人遇到同样的问题,那就去做吧。

docker network ls

此命令列出所有docker网络。当您运行docker-compose时,docker-compose将创建一个新网络。在我的情况下,网络被命名为myapp_default。

注意:为应用程序的网络提供一个基于“项目名称”的名称,该名称基于其所在目录的名称。您可以使用--project-name标志或COMPOSE_PROJECT_NAME环境变量来覆盖项目名称。 。撰写网络

因此,链接到这些容器的正确方法是

docker run --link my_app_mq_1:mq --link my_app_db_1:db -it --net myapp_default worker 

9
对于那些没有注意到的用户,您必须--net在命令前放置。我在尝试运行官方Redis Docker映像时遇到此问题。
Mistertee

3
我必须使用--network标志,而不是--net。在运行命令开始时使用它。我希望这有帮助。参考可以在这里找到:docs.docker.com/engine/reference/run/#network-settings
艾里索(Erizo)'17年


2

使用服务定义版本2及更高版本时,将docker-compose创建用户定义的网络。用户定义网络中的名称解析可通过Docker嵌入式DNS服务器进行。这是文档中的相关报价:

Docker嵌入式DNS服务器为连接到给定[用户定义]网络的容器启用名称解析。这意味着任何连接的容器都可以通过其容器名称对同一网络上的另一个容器执行ping操作。

docker-compose创建的网络别名也可以使用容器。可以通过以下命令验证:

docker inspect \
  -f '{{json .NetworkSettings.Networks.myapp_default.Aliases}}' my_app_db_1

它打印["db","$CONTAINER_ID"]

--link在现有的用户定义网络的情况下,提供链接不会有任何影响。您可以确保查看/etc/hosts,其中没有相应的行。

因此,以下命令就足够了:

docker run -it --net myapp_default worker
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.