主管 - 如何运行多个命令

时间:2015-03-11 18:32:32

标签: python celery supervisor

我正在管理一个通过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文件(导致只运行原始/第一个)。

1 个答案:

答案 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