1

我已经配置了 Django + Celery:一切正常,我可以执行从 views.py 调用的任务,即mul.apply_async((2, 5), queue='celery', countdown=5)

我需要安排定期任务,将简单任务与用户传递的参数链接起来。我阅读了文档http://docs.celeryproject.org/en/latest/userguide/canvas.html并且知道如何链接,我知道如何在没有参数的情况下进行周期性任务@periodic_task(run_every=(crontab(hour="*", minute="*", day_of_week="*")))

但是如何结合呢?

我想要的工作流程:

  1. 用户使用参数创建项目。使用该参数执行了 5 个任务。
  2. 然后我需要 shedule 每 24 小时重复所有 5 个任务。所以在这里我不知道如何传递参数(它们保存到数据库)。

在其他答案中,我看到了这种语法:

CELERYBEAT_SCHEDULE = {
# crontab(hour=0, minute=0, day_of_week='saturday')
'schedule-name': {  # example: 'file-backup' 
    'task': 'some_django_app.tasks....',  # example: 'files.tasks.cleanup' 
    'schedule': crontab(...)
    'args': (2, 3)
},

}

但这里的问题是它位于 Django 的 settings.py 中,但不在 tasks.py 中,我无法动态传递 args。

4

1 回答 1

1

您注册的 celerybeat 任务可以是一个包装器,并在其中执行项目/任务逻辑,并酌情触发其他任务。您可以在 celery beat 工作中获取项目任务。

  • CELERYBEAT_SCHEDULE.task->'some_django_app.project_beat_task'

然后项目节拍任务可以检索正确的项目和与之关联的所有任务,可能为每个项目生成一系列任务

于 2016-03-03T18:52:30.723 回答