我正在尝试执行小组任务,并等到所有小组子任务完成后再运行最后一个任务。但是,当我调用任务时,它将调用组和最后一个任务,但是最后一个任务在组完成之前已经完成。是否可以等到小组中的所有任务完成?
@shared_task(name="print")
def print_order():
print("PRINT #1")
mylist = [(1, 2), (4, 6), (1, 4)]
group([(add.s(*i) | order_id_print.s()) for i in mylist]).delay()
@shared_task(name="print.add")
def add(x,y):
print("ADD #2")
chain(add_task1.s(x, y, 'task id') | add_task2.si(x, y, "task_id")).delay()
return x+y
@shared_task(name="add_task_1")
def add_task1(order_id, ftype, task_id):
print("ADD task #2-1")
print("add tasks task1 order_id {} {} {}".format(order_id, ftype, task_id))
@shared_task(name="add_task_2")
def add_task2(order_id, ftype, task_id):
print("ADD task #2-2")
print("add tasks task2 order_id {} {} {}".format(order_id, ftype, task_id))
@shared_task(name="print.order_id_print")
def order_id_print(id):
print("ORDER #3")
print("order id is {}".format(id))
答案 0 :(得分:2)
您可能想要的是和弦而不是一个和弦。和弦是仅在组中的所有任务完成执行后才执行的任务。
看看文档:
https://docs.celeryproject.org/en/latest/userguide/canvas.html#chords