从不同的docker-compose.yml部署容器

时间:2019-02-28 19:07:26

标签: docker docker-compose rabbitmq celery

目前,我有一个 rabbitmq 消息代理和多个需要容器包装的芹菜工人。我的问题是,如何使用不同的docker-compose.yml启动容器?我的目标是一劳永逸地启动 rabbitmq ,永远不要再碰它。

目前,我有一个docker-compose.yml用于 rabbitmq

version: '2'
services:
    rabbit:
        hostname: rabbit
        image: rabbitmq:latest
        environment:
            - RABBITMQ_DEFAULT_USER=admin
            - RABBITMQ_DEFAULT_PASS=mypass
        ports:
            - "5672:5672"
        expose:
            - "5672"

还有一个docker-compose.yml用于芹菜工人

version: '2'
services:
    worker:
        build:
            context: .
            dockerfile: dockerfile
        volumes:
            - .:/app
        environment:
            - CELERY_BROKER_URL=amqp://admin:mypass@rabbit:5672
        links:
            - rabbit

但是,当我为芹菜工人docker-compose up时,会不断出现以下错误:

ERROR/MainProcess] consumer: Cannot connect to 
amqp://admin:**@rabbit:5672//: failed to resolve broker hostname.

任何人都可以看看我的代码有什么问题吗?谢谢。

2 个答案:

答案 0 :(得分:1)

第二个docker-compose.yml文件中的域名rabbit无法解析,因为该docker-compose.yml文件中没有使用该名称的服务。

如评论中所述,一种解决方案是将rabbit服务和worker服务都放在同一docker-compose.yml文件中。在这样的设置中,为这些服务启动的所有容器都将加入相同的docker网络,并且可以将这些服务名称解析为其容器的IP地址。

由于在您的情况下只有一个docker-compose.yml文件不方便,因此您必须找到另一种方法,使源自不同docker-compose.yml文件的容器加入同一docker网络。

为此,您需要为此创建专用的docker network

docker network create rabbitNetwork

然后,在每个docker-compose.yml文件中,您需要在服务定义中refer to this network

version: '2'
services:
    rabbit:
        hostname: rabbit
        image: rabbitmq:latest
        environment:
            - RABBITMQ_DEFAULT_USER=admin
            - RABBITMQ_DEFAULT_PASS=mypass
        # ports:
        #    - "5672:5672"  # there is no need to publish ports on the docker host anymore
        expose:
            - "5672"
        networks:
            - rabbitNet

networks:
  rabbitNet:
    external:
      name: rabbitNetwork
version: '2'
services:
    worker:
        build:
            context: .
            dockerfile: dockerfile
        volumes:
            - .:/app
        environment:
            - CELERY_BROKER_URL=amqp://admin:mypass@rabbit:5672
        networks:
            - rabbitNet

networks:
  rabbitNet:
    external:
      name: rabbitNetwork

答案 1 :(得分:0)

您可以使用任何文件作为服务定义。 docker-compose.yml是默认文件名,但可以使用-f参数传递任何其他名称。

docker-compose -f rabbit-compose.yml COMMAND