我想执行按节拍安排的复杂任务。让我们假设定义了默认的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
我该如何安排芹菜节拍的非平凡任务?
答案 0 :(得分:0)
一种执行此操作的方法是使用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': ()
}
}