我一直想知道并寻找解决方案,但我没有找到任何解决方案。
我在用 docker-compose 构建的容器中运行 Celery。我的容器配置如下:
celery:
build: .
container_name: cl01
env_file: ./config/variables.env
entrypoint:
- /celery-entrypoint.sh
volumes:
- ./django:/django
depends_on:
- web
- db
- redis
stop_grace_period: 1m
我的入口点脚本如下所示:
#!/bin/sh
# Wait for django
sleep 10
su -m dockeruser -c "celery -A myapp worker -l INFO"
现在,如果我运行
docker-compose stop
,我想要一个温暖的(优雅的)关机,给 Celery 提供的 1 分钟( stop_grace_period
)来完成已经开始的任务。然而docker-compose stop
似乎立即杀死 celery 。 Celery 还应该记录它被要求正常关闭,但除了突然停止我的任务日志之外,我什么也没看到。我做错了什么或者我需要改变什么才能让 Celery 优雅地关闭?
编辑:
下面关于提供
--timeout
的建议答案docker-compose stop
的参数不能解决我的问题。
最佳答案
您需要标记celery
处理 exec
,这样 celery 进程将具有与 docker 命令相同的 ID,docker 将能够向它发送 SIGTERM 信号并优雅地关闭 celery 进程。
# should be the last command in script
exec celery -A myapp worker -l INFO
关于django - docker-compose 和优雅的 celery 关闭,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43276342/