我正在尝试使用主管从我的虚拟环境中运行芹菜。该脚本似乎无法正常工作
我的所有主管脚本都在/etc/supervisord
目录中
它有一个supervisord.conf
文件和目录conf.d
,其中包含文件Gorgon-celery.conf
我的supervisord.conf
文件如下所示:
[unix_http_server]
file=/tmp/supervisor.sock ; (the path to the socket file)
[supervisord]
logfile=/var/log/supervisord/main.log ; (main log file;default $CWD/supervisord.log)
logfile_maxbytes=50MB ; (max main logfile bytes b4 rotation;default 50MB)
logfile_backups=10 ; (num of main logfile rotation backups;default 10)
loglevel=info ; (log level;default info; others: debug,warn,trace)
pidfile=/tmp/supervisord.pid ; (supervisord pidfile;default supervisord.pid)
nodaemon=false ; (start in foreground if true;default false)
minfds=1024 ; (min. avail startup file descriptors;default 1024)
minprocs=200 ; (min. avail process descriptors;default 200)
childlogdir=/var/log/supervisord ; ('AUTO' child log dir, default $TEMP)
[rpcinterface:supervisor]
supervisor.rpcinterface_factory = supervisor.rpcinterface:make_main_rpcinterface
[supervisorctl]
serverurl=unix:///tmp/supervisor.sock ; use a unix:// URL for a unix socket
[include]
files = /etc/supervisord/conf.d/*.conf
我的Gorgon-celery.conf
文件如下所示:
[program:Gorgon-celery]
command=cd /home/ubuntu/sites/source && source ../virtualenv/bin/activate && celery -A Gorgon worker
environment=PYTHONPATH=/home/ubuntu/sites/virtualenv/bin
directory=/home/ubuntu/sites/source
numprocs=1
stdout_logfile=/var/log/celeryd/Gorgon.log
stderr_logfile=/var/log/celeryd/Gorgon.log
autostart=true
autorestart=true
startsecs=10
stopwaitsecs = 600
[program:Gorgon-celerybeat]
command=cd /home/ubuntu/sites/source && source ../virtualenv/bin/activate && celery -A Gorgon beat --max-interval=10
environment=PYTHONPATH=/home/ubuntu/sites/virtualenv/bin
directory=/home/ubuntu/sites/source
numprocs=1
stdout_logfile=/var/log/celeryd/Gorgon-beat.log
stderr_logfile=/var/log/celeryd/Gorgon-beat.log
autostart=true
autorestart=true
startsecs=10
stopwaitsecs = 600
最后,对于主管,我正在使用命令:sudo supervisord -c /etc/supervisord/supervisord.conf
答案 0 :(得分:2)
尝试替换
command=cd /home/sourabh_workaholic_gmail_com/sites/source && source ../virtualenv/bin/activate && celery -A Gorgon beat --max-interval=10
带
command=bash /home/sourabh_workaholic_gmail_com/script.sh
现在在script.sh
并提出以下内容:
#!/bin/bash
cd /home/sourabh_workaholic_gmail_com/sites/source
source ../virtualenv/bin/activate
celery -A Gorgon beat --max-interval=10
我怀疑你不能在supervisorctl中使用source
命令,因为它不会在shell中执行你的命令字符串。 source
是由bash shell提供的命令,因此我们将命令放在bash
脚本中,以便它们可以工作。