我使用芹菜与MySQL
。我想将任务id存储为数据库中的普通整数或芹菜task
的变量。我该怎么做呢?
为什么不创建一个芹菜任务模型,并保存一个芹菜任务id到该模型?
class CeleryModel(models.Model):
celery_task_id = models.CharField(max_length = 50, unique=True)
:
def some_celery_task():
result = celery_task.delay()
celery_task = CeleryModel(celery_task_id = result.id)
celery_task.save() # added save line
您的整数值将是:celery_task.id
,以对应于实际的,唯一的celery_task_id。
UPDATE: another way…
第一个python manage.py inspectdb > inspectdb.py
。在该文件中你会发现:
class CeleryTaskmeta(models.Model):
id = models.IntegerField(primary_key=True)
task_id = models.CharField(max_length=765, unique=True)
status = models.CharField(max_length=150)
result = models.TextField(blank=True)
date_done = models.DateTimeField()
traceback = models.TextField(blank=True)
hidden = models.IntegerField()
meta = models.TextField(blank=True)
class Meta:
db_table = u'celery_taskmeta'
下一步,python manage.py startapp celery_model
。将此文件放入models.py文件中。我用的是南,所以最后一步是python manage.py convert_app celery_model
。然而,这是不必要的。现在你有了django级别的权限来访问这个芹菜数据表,并且可以读取每个任务的主键作为整数值。如
>>> ct = CeleryTaskmeta.objects.get(id=1)
>>> for k,v in ct.__dict__.items(): print k,v
...
status SUCCESS
task_id 2fa95f24-7640-434c-9fef-0732ac1d23c7
date_done 2013-02-17 19:22:56+00:00
traceback None
_state <django.db.models.base.ModelState object at 0x10263fa90>
meta eJxrYKotZAzlSM7IzEkpSs0rZIotZC7WAwBREgb9
result gAJLBC4=
hidden 0
id 1
聪明的人应该知道如何让你的CeleryTaskmeta
成为只读模型,因为我认为你不会想要篡改数据表。
更新:到你问题的最后一部分:
>>> from celerytest.tasks import add
>>> result = add.delay()
>>> result.int_id = 1
>>> for k,v in result.__dict__.items(): print k,v
...
parent None
app <Celery default:0x10264df10>
task_name celerytest.tasks.add
int_id 1
id 01503afd-d196-47af-8e10-e7dc06603cfc
backend <djcelery.backends.database.DatabaseBackend object at 0x1026842d0>
要在任务启动时获取芹菜任务ID,我执行以下操作:
process_task = my_task.apply_async(args=[args])
task_id = process_task.task_id
其中my_task是tasks.py中的一个方法