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



我想在Digitalocean上与Docker部署我的小网络应用程序。问题是,我没有分开烧瓶 芹菜,所以一切都在一个容器中。每次我运行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",一切都很好,因为芹菜没有运行。网页正常运行,数据库处于活动状态。一切都很好,除了芹菜。

通过取消注释命令行,Docker抛出了"网络中使用错误代码0"。

我猜这是由于事实是,Docker成功执行命令后退出了容器。所以我面临两个问题:

1(如何在同一芹菜容器的背景下运行芹菜,以免出现错误代码0?

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

->我已经尝试了以下情况,但是同样的错误:

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

任何帮助都非常感谢:(

编辑:我将芹菜 烧瓶放在一个容器中的原因是我的任务。在这里,我从Web.webapp.models导入所有SQLalchemy模型。因此,我需要访问烧瓶目录,目前我看不到如何将其分成两个容器

如果您需要在两个不同过程之间"共享"的唯一一件事是代码,则已经在构建的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构成了默认网络,并将所有服务附加到它使用他们的服务块的名称。我还删除了许多其他无关紧要的选项。(

相关内容

  • 没有找到相关文章

最新更新