我刚刚安装了Celery并且正在尝试按照教程进行操作:
我有一个名为tasks.py的文件,其中包含以下代码:
from celery import Celery
app = Celery('tasks', backend='amqp', broker='amqp://')
@app.task
def add(x, y):
return x + y
我安装了RabitMQ(我没有配置它,因为教程没有提到任何类型的东西)。
我按如下方式运行芹菜工作服务器:
celery -A tasks worker --loglevel=info
似乎正常启动(这是输出:http://i.imgur.com/qnoNCzJ.png)
然后我运行以下脚本:
from tasks import add
from time import sleep
result = add.delay(2,2)
while not result.ready():
sleep(10)
当我检查result.ready()
时,我总是得到假(所以上面的while循环永远运行)。然而,在Celery日志中,一切看起来都很好:
[2014-10-30 00:58:46,673: INFO/MainProcess] Received task: tasks.add[2bc4ceba-1319-49ce-962d-1ed0a424a2ce]
[2014-10-30 00:58:46,674: INFO/MainProcess] Task tasks.add[2bc4ceba-1319-49ce-962d-1ed0a424a2ce] succeeded in 0.000999927520752s: 4
所以这项任务得到了回应并取得了成功。然而,result.ready()
仍然是假的。任何有关为什么会这样的见解?我在Windows 7上,正在使用RabbitMQ。提前谢谢。
答案 0 :(得分:3)
应该解决你的问题
ignore_result=False
答案 1 :(得分:2)
好的,我已经设置了一个带有新芹菜安装的清除虚拟机,设置了以下文件:
tasks.py:
from celery import Celery
app = Celery('tasks', backend='amqp', broker='amqp://')
@app.task
def add(x, y):
return x + y
和runme.py
from tasks import add
import time
result = add.delay(1,2)
while not result.ready():
time.sleep(1)
print(result.get())
然后我用:
设置芹菜celery -A tasks worker --loglevel=info
然后我运行runme.py,它给出了预期的结果:
[puciek@somewhere tmp]# python3.3 runme.py
3
很明显,问题出在你的设置中,很可能是在Rabbit-mq安装的某个地方,所以我建议从源代码中重新安装最新的稳定版本,这就是我正在使用的,正如你所看到的 - 它工作得很好
更新
实际上,您的问题可能与想象的一样微不足道 - 您确定您使用相同的版本进行芹菜运行,并运行您的消费者吗?我只是设法重现它,我在Python3.3上运行芹菜,随后用2.7版运行runme.py。结果如您所述。
答案 2 :(得分:0)