celerybeat会自动禁用定期任务

时间:2011-05-25 08:04:29

标签: django celery django-celery celeryd

我想使用 django-celery 的管理界面为芹菜创建一个定期任务。我有一个任务设置,在手动或脚本调用时运行良好。它只是不能通过 celerybeat 工作。根据调试日志,第一次检索时任务设置为enabled = False,我想知道为什么。

添加周期性任务并将[1, False]作为位置参数传递时,任务会自动禁用,我看不到任何进一步的输出。如果在没有参数的情况下添加任务,则会执行任务,但会立即引发异常,因为我没有提供所需的参数(有意义)。

有人看到这里有什么问题吗?

提前致谢。

这是提供参数后的输出:

[DEBUG/Beat] SELECT "djcelery_periodictask"."id", [...] 
             FROM "djcelery_periodictask" 
             WHERE "djcelery_periodictask"."enabled" = true ; args=(True,)

[DEBUG/Beat] SELECT "djcelery_intervalschedule"."id", [...] 
             FROM "djcelery_intervalschedule" 
             WHERE "djcelery_intervalschedule"."id" = 3 ; args=(3,)

[DEBUG/Beat] SELECT (1) AS "a" 
             FROM "djcelery_periodictask" 
             WHERE "djcelery_periodictask"."id" = 3  LIMIT 1; args=(3,)

[DEBUG/Beat] UPDATE "djcelery_periodictask" 
             SET "name" = E'<taskname>', "task" = E'<task.module.path>', 
                 "interval_id" = 3, "crontab_id" = NULL, 
                 "args" = E'[1, False,]', "kwargs" = E'{}', "queue" = NULL, 
                 "exchange" = NULL, "routing_key" = NULL, 
                 "expires" = NULL, "enabled" = false, 
                 "last_run_at" = E'2011-05-25 00:45:23.242387', "total_run_count" = 9, 
                 "date_changed" = E'2011-05-25 09:28:06.201148' 
             WHERE "djcelery_periodictask"."id" = 3; 
             args=(
                   u'<periodic-task-name>', u'<task.module.path>', 
                   3, u'[1, False,]', u'{}', 
                   False, u'2011-05-25 00:45:23.242387', 9, 
                   u'2011-05-25 09:28:06.201148', 3
             )

[DEBUG/Beat] Current schedule:
<ModelEntry: celery.backend_cleanup celery.backend_cleanup(*[], **{}) {<crontab: 0 4 * (m/h/d)>}
[DEBUG/Beat] Celerybeat: Waking up in 5.00 seconds.

修改 它适用于以下设置。我仍然不知道为什么它不适用于 django-celery

CELERYBEAT_SCHEDULE = {
    "example": {
        "task": "<task.module.path>",
        "schedule": crontab(),
        "args": (1, False)
    },
}

2 个答案:

答案 0 :(得分:15)

我有同样的问题。确保参数是JSON格式的。例如,尝试将位置参数设置为[1,false] - 小写“false” - 我只是在django-celery实例(版本2.2.4)上测试它并且它有效。

对于关键字args,请使用{“name”:“aldarund”}

之类的内容

答案 1 :(得分:7)

我也遇到了同样的问题。

在djcelery中描述PeriodicTask模型(“JSON编码位置参数”),与Evan回答相同。我尝试在保存之前使用python json lib进行编码。

这与我合作

import json 
o = PeriodicTask()
o.kwargs = json.dumps({'myargs': 'hello'})
o.save()

芹菜版3.0.11