在与Flask应用程序不同的docker容器中运行celery时出现问题

时间:2018-09-12 09:53:31

标签: python-3.x docker flask docker-compose celery

我正在用Celery运行Flask应用程序,以便使用docker-compose提交子流程。 但是,当尝试在其他容器中运行Celery时,我无法使其工作。

如果我在同一容器中运行Celery,则我正在运行烧瓶应用程序,但是感觉好像是错误的方式,我将两个不同的东西耦合到一个容器中,方法是在烧瓶应用程序之前的启动脚本中添加此容器运行:

nohup celery worker -A app.controller.engine.celery -l info &

但是,如果我将Celery作为新容器添加到docker-compose.yml中,它将无法正常工作。这是我的配置:

(..)

engine:
  image: engine:latest
  container_name: engine
  ports:
    - 5000:5000
  volumes:
    - $HOME/data/engine-import:/app/import
  depends_on:
    - mongo
    - redis
  environment:
    - HOST=localhost

celery:
  image: engine:latest
  environment:
        - C_FORCE_ROOT=true
  command: ["/bin/bash", "-c", "./start-celery.sh"]
  user: nobody
  depends_on:
    - redis

(..)

这是start-celery.sh:

#!/bin/bash
source ./env/bin/activate

cd ..
celery worker -A app.controller.engine.celery -l info

它的日志:

INFO:engineio:Server initialized for eventlet.
INFO:engineio:Server initialized for threading.
[2018-09-12 09:43:19,649: INFO/MainProcess] Connected to redis://redis:6379//
[2018-09-12 09:43:19,664: INFO/MainProcess] mingle: searching for neighbors
[2018-09-12 09:43:20,697: INFO/MainProcess] mingle: all alone
[2018-09-12 09:43:20,714: INFO/MainProcess] celery@8729618bd4bc ready.

仅此而已,流程未提交给它。

可能缺少什么?

1 个答案:

答案 0 :(得分:0)

我发现只有将其添加到celery服务的docker-compose定义中,它才有效:

environment: 
      - C_FORCE_ROOT=true

我想知道为什么我没有其他错误。