我发现celery支持任务链: http://celery.readthedocs.org/en/latest/userguide/canvas.html#chains.
问题是: 如何在任务中停止链的执行?
例如,我们有一个由N个项目组成的链(N > 2)。在第二个任务中,我们意识到不需要执行所有剩余的任务。该怎么做?
我发现celery支持任务链: http://celery.readthedocs.org/en/latest/userguide/canvas.html#chains.
问题是: 如何在任务中停止链的执行?
例如,我们有一个由N个项目组成的链(N > 2)。在第二个任务中,我们意识到不需要执行所有剩余的任务。该怎么做?
# 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)