celery - 如何在 celery 中安排链式任务

标签 celery schedule chain

我想运行一个由beat 调度的复杂任务。让我们假设定义了默认的 add/mul 任务。

@app.on_after_configure.connect
def setup_periodic_tasks(sender, **kwargs):
    sender.add_periodic_task(
        crontab(),
        add.s(2,3) | mul.s(2)
    )

但这将在工作人员中返回错误:
NotImplementedError: chain is not a real task

如何使用 celery beat 安排一项重要的任务?

最佳答案

一种方法是在 beat_schedule 中安排您的任务链在您的 celeryconfig , 使用 link选项,celery_tasks这是定义您的任务的模块名称

from celery.schedules import crontab
from celery import signature

beat_schedule = {
    'chained': {
        'task': 'celery_tasks.add',
        'schedule': crontab(),
        'options': {
            'queue': 'default',
            'link': signature('celery_tasks.mul',
                        args=(),
                        kwargs={},
                        options={
                            'link': signature('celery_tasks.another_task', 
                                args=(),
                                kwargs={}, 
                                queue='default')
                        },
                        queue='default')
            },
         'args': ()
    }
}

关于celery - 如何在 celery 中安排链式任务,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56460538/

相关文章:

redis - django-celery celerybeat 周期性任务每 5 秒运行一次,与间隔无关

Django celery 任务 : Newly created model DoesNotExist

iphone - Cocos2d - Iphone ScheduleUpdate 更新未被调用

javascript - 调用 ajax 调用序列的模式?

javascript - 如何使用作为生成器并能够链接它们的函数来扩展数组?

javascript - 原型(prototype)链

python - 使用 Celery 创建动态队列

flask - 如何让 flask 将生成器传递给 celery 等任务

sql - 在预订表中只允许工作时间

angular2 使用 PrimeNG-Scheduler 实现 FullCalendar-Scheduler