如何在一个容器中运行烧瓶和芹菜?

时间:2019-08-03 10:11:19

标签: python docker flask celery

我想用docker在digitalocean上部署我的小型Web应用程序。问题是,我没有将烧瓶和芹菜分开,所以所有东西都放在一个容器中。 每次我运行docker-compose up时,Web容器都会崩溃(“代码为0退出”)。

项目结构如下:

.
.
├── docker-compose.yml
├── nginx
│   ├── dockerfile
│   └── nginx.conf
└── web
    ├── app.ini
    ├── bot
    │   ├── __init__.py
    │   ├── main.py
    │   ├── __pycache__
    │   └── timer.py
    ├── celeryd.pid
    ├── config.py
    ├── dockerfile
    ├── dockerignore
    ├── flask_app.py
    ├── __init__.py
    ├── requirements.txt
    ├── tasks.py
    └── webapp
        ├── bot
        ├── __init__.py
        ├── models.py
        ├── __pycache__
        ├── static
        ├── templates
        └── users

这是docker-compose.yml:

version: "3.7"

services:

  rabbitmq:
    image: rabbitmq:3-management
    hostname: rabbitmq
    container_name: rabbitmq
    environment:
      RABBITMQ_ERLANG_COOKIE: 'SWQOKODSQALRPCLNMEQG'
      RABBITMQ_DEFAULT_USER: 'user123'
      RABBITMQ_DEFAULT_PASS: 'password123'
      RABBITMQ_DEFAULT_VHOST: '/webapp'
    ports:
      - "15672:15672"
      - "5672:5672"
    volumes:
      - rabbitmq_storage:/var/lib/rabbitmq
    networks:
      netzwerk123:
        aliases:
          - rabbitmq

  db:
    image: mariadb
    restart: always
    container_name: db
    environment:
      MYSQL_ROOT_PASSWORD: 'password123'
      MYSQL_USER: 'user123'
      MYSQL_PASSWORD: 'password123'
      MYSQL_DATABASE: 'webapp'
    ports:
      - "3306:3306"
    volumes:
      - db_storage:/var/lib/mysql
    networks:
      netzwerk123:
        aliases:
          - db


  nginx:
    build: ./nginx  
    container_name: nginx
    restart: always
    ports:  
      - "80:80"
    networks:
      netzwerk123:
        aliases:
          - ngnix


  web:
    build: ./web  
    container_name: web
    hostname: web
    restart: always
    environment:    
      FLASK_DEBUG: 'True'
      FLASK_APP: 'flask_app.py'
    command: celery -A tasks.celery worker --loglevel=info --detach
    expose:
      - 8080
    networks:
      netzwerk123:
        aliases:
          - web
    depends_on:     
      - nginx
      - db
      - rabbitmq
    links:
      - rabbitmq
    tty: true
    stdin_open: true


  adminer:        #only for development purposes
    image: adminer
    container_name: adminer
    restart: always
    ports:
      - "8081:8080"
    depends_on:
      - db
    networks:
      netzwerk123:
        aliases:
          - adminer



volumes:                                    
  db_storage:
  rabbitmq_storage:

networks:
  netzwerk123:

如果我评论"command: celery -A tasks.celery worker --loglevel=info --detach",那么一切都很好,因为芹菜没有运行。网页功能全面,数据库处于活动状态。除了芹菜,一切都很好。

通过取消注释命令行,码头工人抛出“错误代码为0退出的网络”。

我猜这是由于以下事实,即docker在成功执行命令后退出了容器。因此,我面临两个问题:

1)如何在同一个芹菜容器的后台运行celery,以免出现错误代码0?

2)如何在容器中平行运行芹菜和烧瓶?

->我已经尝试过以下操作,但存在相同的错误:

command: bash -c "uwsgi app.ini && celery -A tasks.celery worker --loglevel=info --detach"

我们非常感谢您的帮助:)

编辑: 我将芹菜+烧瓶放在一个容器中的原因是我的task.py。在这里,我从web.webapp.models中导入所有sqlalchemy模型。因此,我需要访问flask目录,并且目前我没有办法将其分为两个容器

1 个答案:

答案 0 :(得分:1)

如果您需要在两个不同进程之间“共享”的唯一东西是代码,那么该代码已经在构建的Docker映像中。您可以很容易地在同一映像上运行两个不同的容器,但是使用不同的命令。

services:
  web:
    build: ./web  
    environment:    
      FLASK_DEBUG: 'True'
      FLASK_APP: 'flask_app.py'
    command: flask run --host=0.0.0.0
    depends_on:     
      - nginx
      - db
      - rabbitmq
  celery:
    build: ./web  
    restart: always
    command: celery -A tasks.celery worker --loglevel=info
    depends_on:     
      - db
      - rabbitmq

请注意,两个build:都是同一张图片。另外,我使celery worker不是--detach,所以它作为前台进程运行;只要command:仍在运行,容器将保持运行。

(要使此片段在原始docker-compose.yml文件的上下文中起作用,您需要彻底删除整个文件中的所有networks:块,但它将正常工作:Docker Compose创建默认网络,并使用其服务块的名称将所有服务附加到该网络。我还删除了许多其他无关紧要的选项。)