如何在芹菜中设置回调

时间:2012-09-14 12:43:12

标签: python celery

我想在函数中添加回调,以便在返回时可以调用常规的python函数,

我的任务

@celery.task                                                                                                                            
def add(x, y):                                                                                                                         
    return x + y 

我想如何使用它:

from __future__ import print_function
delay.add(2, 3 ,callback=lambda x: print x) 

它可以是任何未在芹菜任务中定义的函数,而不是lambda 但是从哪里调用任务。

1 个答案:

答案 0 :(得分:3)

在这种情况下,您只能链接任务:

add.apply_async((2, 3), link=other_task.s())

与:

相同
(add.s(2, 3) | other_task.s())()

等待任务完成使任务同步,因此您想要的呼叫会 相当于:

(lambda x: print(x))(add.delay(2, 3).get())

在任务返回之前会阻止当前进程。 如果您不希望该进程被阻止,那么您将不得不写 一个等待结果并调用回调的专用线程。

或者您可以使用eventlet / gevent并且几乎可以编写普通代码。