2013-03-04 9 views

答えて

12

セロリタスクモデルを作成し、そのモデルにセロリタスク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:別の方法...

まず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読み取り専用のモデルを作成する方法を知っているだろう。

UPDATE:あなたの質問の最後の部分に:

>>> 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> 
+0

徹底的でクリーンな説明をありがとう! – pynovice

+1

問題は、プロセスの開始時にtask_idを取得したいのですか? CeleryTaskMetaテーブルにデータが書き込まれるのは、ジョブが正常に完了した後だけです。 – pynovice

+0

@Cole非同期スクレイプの結果をデータベースに保存するにはどうすればよいですか? – losee

0

はセロリのタスクIDを取得するには、タスクが開始されたとき、私は次の操作を行います。

my_taskは内のメソッドである
process_task = my_task.apply_async(args=[args]) 
task_id = process_task.task_id 

tasks.py

関連する問題