我想用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目录,并且目前我没有办法将其分为两个容器
答案 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创建默认网络,并使用其服务块的名称将所有服务附加到该网络。我还删除了许多其他无关紧要的选项。)