我试图让主管监视和维护一个使用 Huey(redis 类型队列)的 python 脚本。

我的主管程序配置如下所示:

[program:smsbot_handler]
directory=/home/ubuntu/virt_env/virt1/app/
command=/home/ubuntu/virt_env/virt1/bin/huey_consumer.py main.huey --threads=3
stdout_logfile=/home/ubuntu/smsbot_handler_log.txt
autostart=true
autorestart=true
environment=PYTHONPATH="/home/ubuntu/virt_env/virt1/app:$PYTHONPATH"
redirect_stderr=true

任何人都可以给我任何线索,为什么这不起作用?我在日志文件中得到的只是:
Error importing main.huey

它真的开始接近我了!

最佳答案

假设你已经测试过你的命令在不是从主管启动时运行良好,我会删除环境行,而是启动一个 shell 脚本,设置环境并从 shell 脚本(使用 exec python)启动huey_consumer.py。

这就是我对所有需要在主管下的特定环境的程序所做的。

下面是一个例子:

在主管配置中:

[program:MyExample]
command=/ama/nms/MyExample/supervisor_myexample.sh
process_name=%(program_name)s ; process_name expr (default %(program_name)s)
numprocs=1                    ; number of processes copies to start (def 1)
directory=/ama/nms/MyExample  ; directory to cwd to before exec (def no cwd)
priority=10                   ; the relative start priority (default 999)
autostart=true                ; start at supervisord start (default: true)
autorestart=true              ; retstart at unexpected quit (default: true)
startsecs=1                   ; number of secs prog must stay running (def. 1)
startretries=10                ; max # of serial start failures (default 3)
exitcodes=0,2                 ; 'expected' exit codes for process (default 0,2)
stopsignal=TERM               ; signal used to kill process (default TERM)
stopwaitsecs=10               ; max num secs to wait b4 SIGKILL (default 10)

在文件/ama/nms/MyExample/supervisor_myexample.sh 中:
#!/bin/sh
# ------------------------------------------

# Set the environment
export LD_LIBRARY_PATH=<...>:$LD_LIBRARY_PATH
export PYTHONPATH=<...>:$PYTHONPATH

D=`dirname $0`
exec python $D/myexample.py arg1 arg2 arg3

关键是使用 exec 启动命令,以便主管可以监视启动的命令的 pid。

关于python - 主管保持 Huey python 运行,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/19918574/

10-11 08:06