4

我在设置 python-rq 时面临一个基本问题 -rqworker似乎无法识别推送到它正在侦听的队列的作业。

一切都在里面运行virtualenv
我有以下代码:

from redis import Redis
from rq import Queue
from rq.registry import FinishedJobRegistry
from videogen import videogen
import time

redis_conn = Redis(port=5001)
videoq = Queue('medium', connection=redis_conn)
fin_registry = FinishedJobRegistry(connection=redis_conn, name='medium')

jobid = 1024
job = videoq.enqueue(videogen, jobid)

while not job.is_finished:
    time.sleep(2)
    print job.result

videogen是一个简单的函数,它立即返回它接收到的整数参数。

在运行rqworker medium和启动应用程序时,没有打印任何结果。rqworker 上没有额外的痕迹,除此之外:

14:41:29 RQ worker started, version 0.5.0
14:41:29 
14:41:29 *** Listening on medium...

可以从我运行 rqworker 的同一个 shell 访问 redis 实例,甚至显示更新的密钥:

127.0.0.1:5001> keys *
1) "rq:queues"
2) "rq:queue:medium"
3) "rq:job:9a46f9c5-03e1-4b08-946b-61ad2c3815b1"

那么这里可能缺少什么?

4

1 回答 1

8

愚蠢的错误 - 必须向 rqworker 提供 redis 连接 url
rqworker --url redis://localhost:5001 medium

于 2015-02-26T09:44:25.163 回答