在convox / docker-compose中运行docker容器的错误顺序

时间:2017-02-04 14:51:44

标签: python django nginx docker docker-compose

这是我正在使用的撰写文件。它包含一个postgres db容器和一个redis容器。在他们之上我有一个gunicorn-django-python web服务器(docker image:python-3.5)。有一个nginx代理服务器链接到Web容器。

version: '2'
services:

  nginx:
    build: ./nginx/
    ports:
      - 80:80
    volumes:
      - /usr/src/app/static
    links:
      - web

  web:
    build: ./web
    ports:
      - 8000:8000
    volumes:
      - /usr/src/app/static
    env_file: .env
    environment:
      DEBUG: 'true'
      SECRET_KEY: 5(15ds+i2+%ik6z&!yer+ga9m=e%jcqiz_5wszg)r-z!2--b2d
      DB_NAME: postgres
      DB_USER: postgres
      DB_PASS: postgres
      DB_SERVICE: postgres
      DB_PORT: 5432
    command: /usr/local/bin/gunicorn messanger.wsgi:application -w 2 -b :8000
    links:
      - redis
      - postgres

  postgres:
    image: postgres
    ports:
      - 5432
    volumes:
      - pgdata:/var/lib/postgresql/data/

  redis:
    image: redis
    ports:
      - 6379
    volumes:
      - redisdata:/data

我在通过

启动docker容器时遇到问题
convox start -f docker-compose.yml

问题是,理想情况下首先启动postgres / redis服务器,然后根据链接顺序将Web服务器和nginx服务器最终启动。但实际上Web服务器首先启动,因为它没有db / cache就失败了。请参阅以下错误日志:

web      │ running: docker run -i --rm --name python-app-web -e DB_NAME=postgres -e DB_USER=postgres -e DB_PASS=postgres -e DB_SERVICE=postgres -e DB_PORT=5432 -e DEBUG=true -e SECRET_KEY=5(15ds+i2+%ik6z&!yer+ga9m=e%jcqiz_5wszg)r-z!2--b2d --add-host redis: -e REDIS_SCHEME=tcp -e REDIS_HOST= -e REDIS_PORT=
 -e REDIS_PATH= -e REDIS_USERNAME= -e REDIS_PASSWORD= -e REDIS_URL=tcp://:%0A --add-host postgres: -e POSTGRES_SCHEME=tcp -e POSTGRES_HOST= -e POSTGRES_PORT=
 -e POSTGRES_PATH= -e POSTGRES_USERNAME= -e POSTGRES_PASSWORD= -e POSTGRES_URL=tcp://:%0A -p 0:8000 -v /Users/gaurav/.convox/volumes/python-app/web/usr/src/app/static:/usr/src/app/static python-app/web sh -c /usr/local/bin/gunicorn messanger.wsgi:application -w 2 -b :8000
web      │ invalid argument "redis:" for --add-host: invalid IP address in add-host: ""
web      │ See 'docker run --help'.
postgres │ running: docker run -i --rm --name python-app-postgres -p 5432 -v pgdata:/var/lib/postgresql/data/ python-app/postgres
redis    │ running: docker run -i --rm --name python-app-redis -p 6379 -v redisdata:/data python-app/redis

但是当我完全删除nginx服务器时,它工作正常,在这种情况下,webg服务器在postgres / redis之后被启动。

我无法理解实际错误。

可以在github找到完整代码here

[注意] 发现非常奇怪的事情,我没想到这一点。问题在于容器的名称。如果我将'ngnix'容器重命名为server / webserver / xyz / myngnix / ngnixxxx等,它们按预期和顺序工作。但不使用名称ngnix!奇怪的不是它。

1 个答案:

答案 0 :(得分:0)

只需将depends_on指令添加到docker-compose.yml

即可
version: '2'
services:
  depends_on:
    - web
  nginx:
    build: ./nginx/

    ports:
      - 80:80
    volumes:
      - /usr/src/app/static

  web:
    build: ./web
    depends_on:
     - postrges
     - redis
    ports:
      - 8000:8000
    volumes:
      - /usr/src/app/static
    env_file: .env
    environment:
      DEBUG: 'true'
      SECRET_KEY: 5(15ds+i2+%ik6z&!yer+ga9m=e%jcqiz_5wszg)r-z!2--b2d
      DB_NAME: postgres
      DB_USER: postgres
      DB_PASS: postgres
      DB_SERVICE: postgres
      DB_PORT: 5432
    command: /usr/local/bin/gunicorn messanger.wsgi:application -w 2 -b :8000

  postgres:
    image: postgres
    ports:
      - 5432
    volumes:
      - pgdata:/var/lib/postgresql/data/

  redis:
    image: redis
    ports:
      - 6379
    volumes:
      - redisdata:/data

运行容器的顺序没问题。但这并不意味着当Web应用程序尝试连接到redis时,此容器将可用。如果您想要获得这些内容,您需要whait for itdocker-compose health check

之类的内容