我目前正在用 Celery 测试 Django。
使用 crontab 设置定期任务以运行以下任务添加:
from __future__ import absolute_import
from celery import task
import time
@task
def add(x, y):
print "Start : %s" % time.ctime()
time.sleep(120)
print "End : %s" % time.ctime()
return x + y
该模型:
from django.db import models
from djcelery.models import CrontabSchedule
from djcelery.models import TaskState
class Manager(models.Model):
cron = models.ForeignKey(CrontabSchedule)
def app_status(self):
return self.cron.schedule.app.tasks
app_status.admin_order_field = 'app status'
现在我希望能够访问当前或上一个任务的状态。使用 Django shell,我可以获得以下内容:
>>> import django
>>> from extractionapp.models import Manager
>>> Manager.objects.all()[0].app_status()
{'celery.chain': <@task: celery.chain of proj:0x1022f1a90>, 'celery.chord': <@task: celery.chord of proj:0x1022f1a90>, 'proj.celery.debug_task': <@task: proj.celery.debug_task of proj:0x1022f1a90>, 'celery.chunks': <@task: celery.chunks of proj:0x1022f1a90>, 'celery.chord_unlock': <@task: celery.chord_unlock of proj:0x1022f1a90>, 'celery.group': <@task: celery.group of proj:0x1022f1a90>, 'celery.backend_cleanup': <@task: celery.backend_cleanup of proj:0x1022f1a90>, 'celery.map': <@task: celery.map of proj:0x1022f1a90>, 'celery.starmap': <@task: celery.starmap of proj:0x1022f1a90>}
但是,我无法从此访问添加任务,也无法访问其状态。按名称调用任务也不起作用:
Manager.objects.all()[0].app_status()['extractionapp.tasks.add'] Traceback(最近一次调用最后):文件“”,第 1 行,在文件“/Users/antoinebrunel/seo/lib/ python2.7/site-packages/celery/app/registry.py",第 26 行,缺少 raise self.NotRegistered(key) NotRegistered: 'extractionapp.tasks.add'
那么如何访问分配给 cron 的当前任务的状态呢?我可以通过主页 › Djcelery › 任务从管理员那里看到它,但我如何从代码中获得它?
非常感谢!