我正在管理一个通过Supervisor处理队列的Celery工作人员。
这是我的/etc/supervisor/celery.conf:
[program:celery]
command = /var/worker/venv/bin/celery worker -A a_report_tasks -Q a_report_process --loglevel=INFO
directory=/var/worker
user=nobody
numprocs=1
autostart=true
autorestart=true
startsecs=10
stopwaitsecs = 60
stdout_logfile=/var/log/celery/worker.log
stderr_logfile=/var/log/celery/worker.log
killasgroup=true
priority=998
如何添加第二个命令来运行?
/var/worker/venv/bin/celery worker -A b_report_tasks -Q b_report_process --loglevel=INFO
我尝试将&&
在同一行上的两个命令分开(导致语法错误),在同一个文件中添加一个完全独立的[program:celery]
部分(导致只运行第一个) ),并在同一目录中创建一个完全不同的celery1.conf
文件(导致只运行原始/第一个)。
答案 0 :(得分:26)
使用不同的任务名称添加第二部分。如果两个任务具有相同的任务名称,后者将覆盖前者。
[program:celeryb]
command = /var/worker/venv/bin/celery worker -A b_report_tasks -Q b_report_process --loglevel=INFO
directory=/var/worker
user=nobody
numprocs=1
autostart=true
autorestart=true
startsecs=10
stopwaitsecs = 60
stdout_logfile=/var/log/celery/worker.log
stderr_logfile=/var/log/celery/worker.log
killasgroup=true
priority=998
您还可以对它们进行分组,以便两个任务作为一个组重新启动:
[group:celery-workers]
programs=celery,celeryb
priority=999