Python 芹菜任务链取消?

Python 芹菜任务链取消?,python,celery,delayed-execution,Python,Celery,Delayed Execution,我发现芹菜支持任务链: 问题是:如何在任务中停止链的执行? 例如,我们得到一个由N个项目组成的链(N>2)。在第二个任务中,我们意识到我们不需要执行所有剩余的任务。怎么办?在较新版本的芹菜(3.1.6)中,您可以通过简单地遍历链并依次撤销每个项目来撤销整个链 # Build a chain for results from tasks import addd from celery import chain def revoke_chain(result): while result:

我发现芹菜支持任务链:

问题是:如何在任务中停止链的执行?


例如,我们得到一个由N个项目组成的链(N>2)。在第二个任务中,我们意识到我们不需要执行所有剩余的任务。怎么办?

在较新版本的芹菜(3.1.6)中,您可以通过简单地遍历链并依次撤销每个项目来撤销整个链

# Build a chain for results
from tasks import addd
from celery import chain

def revoke_chain(result):
    while result:
        result.revoke()
        result = result.parent

# independent tasks (with immutable signatures)
c = chain(*tuple(add.si(i,i) for i in xrange(50)))
h = c()

# some time later ...
revoke_chain(h)

# dependant task
c = add.s(1,1) | add.s(2) | add.s(3)
h = c()

# some time later ...
revoke_chain(h)

当您希望任务停止时,在任务中引发异常如何?引发异常对我不起作用。我在这里发布了详细的解释: