gpt4 book ai didi

python - celery 任务链取消?

转载 作者:太空狗 更新时间:2023-10-29 20:28:37 27 4
gpt4 key购买 nike

我发现celery支持任务链:http://celery.readthedocs.org/en/latest/userguide/canvas.html#chains .

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

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

最佳答案

在较新版本的 celery (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)

关于python - celery 任务链取消?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12772556/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com