python - 可以等到 celery 组做好吗?

标签 python django rabbitmq celery messagebroker

我正在尝试执行组任务并等待所有组子任务完成,然后运行最后一个任务。但是,当我调用任务时,它会调用组和最后一个任务,但最后一个任务在组完成之前完成。是否可以等到组内的所有任务完成?

@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))

最佳答案

您可能想要的是和弦而不是组。和弦是仅在组中的所有任务执行完毕后才执行的任务。

查看文档:

https://docs.celeryproject.org/en/latest/userguide/canvas.html#chords

关于python - 可以等到 celery 组做好吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55626750/

相关文章:

重试兔子消息时记录消息

windows - RabbitMq 和 "Fatal error: handshake failure - handshake_decode_error"

java - Beans和RabbitTemplate/RabbitHealth出现TomcatStarter错误

python - 使用 pydoc 将模块索引写入文件,无需服务器

python - 有没有办法在 Excel-VBA 中调用 Python 代码?

python 全局变量在函数中通过 if 语句求值时在函数中不起作用

python - Django CMS - 无法通过 cmsplugin_filer_image 上传图像

Python tarfile 比 Linux 命令慢

python - 如何从 Django 查询集中创建新记录

python - Django - 同一查询中的 objects.values() 和 prefetch_related()