我在Heroku上托管了Django应用程序,但由于一些限制,我从Heroku转移到了基于云的服务器。我遵循这个教程在Python中运行后台任务。一切都运行良好,除了我必须手动运行python worker.py来启动辅助进程之外。
在Heroku上,我们可以在应用程序启动时使用Procfile来运行进程,但是现在我在一个基于云的服务器上运行ubuntu14.04。那么,Procfile的替代方案是什么呢?
worker.py
import os
import redis
from rq import Worker, Queue, Connection
listen = ['high', 'default', 'low']
redis_url = os.getenv('REDISTOGO_URL', 'redis://localhost:6379')
conn = redis.from_url(redis_url)
if __name__ == '__main__':
with Connection(conn):
worker = Worker(map(Queue, listen))
worker.work()发布于 2016-08-15 08:41:20
我最终使用了暴发户。我用下面的代码使用rqworker.py使用sudo nano \etc\init\rqworker.conf创建了一个新的配置文件:
description "Job queues for directory"
start on runlevel [2345]
stop on runlevel [!2345]
respawn
setuid myuser
setgid www-data
exec python3.5 worker.py然后我刚刚启动了服务sudo service rqworker start,现在我的工作进程正在后台运行。
发布于 2016-08-15 08:33:27
使用流程管理器,如upstart、systemd或主管。
https://stackoverflow.com/questions/38947480
复制相似问题