2017-02-09 9 views
0

サブタスクがすべて完了する前に自分のタスクが完了したと考えられる理由がわかりません。セロリ - タスクがサブタスクになる前に成功する

tasks.scan_user.delay(1) 

CODE:あなたが見ることができるよう

@task() 
def scan_chunk(ids): 
    occs = Occurence.objects.filter(product_id__in=ids) 
    result = scan_occurences_dummy_pool((x.id,x.url,x.xpath) for x in occs) 
    return result 

@task() 
def scan_user(id): 
    chunks = generate_chunks_from_user(id) 
    ch = chain(scan_chunk.si([x.id for x in chunk]) for chunk in chunks) 
    return ch() 

これは、セロリ出力され、すべてのscan_chunksが行われる前に、scan_userは、私は別のchainで私たちにscan_userをしたいので、問題である成功しました。

[2017-02-09 14:27:03,493: INFO/MainProcess] Received task: engineapp.tasks.scan_user[ed358a98-a685-4002-baac-993fdc7b64cf] 
[2017-02-09 14:27:05,721: INFO/MainProcess] Received task: engineapp.tasks.scan_chunk[35b74e01-f9fa-471f-8c20-ecbf99a89201] 
[2017-02-09 14:27:06,740: INFO/MainProcess] Task engineapp.tasks.scan_user[ed358a98-a685-4002-baac-993fdc7b64cf] succeeded in 3.24300003052s: <AsyncResult: 442f9373-d983-4696-a42a-ba42a8ce7761> 
[2017-02-09 14:27:22,178: INFO/MainProcess] Received task: engineapp.tasks.scan_chunk[36a94ad4-3c9e-4f7d-a040-5c2a617a0d8f] 
[2017-02-09 14:27:23,204: INFO/MainProcess] Task engineapp.tasks.scan_chunk[35b74e01-f9fa-471f-8c20-ecbf99a89201] succeeded in 17.4779999256s: [ 

私はすべてのユーザーに対して順次scan_userを実行する別のtaskを作成したいと思いますが、私はそれが実際に平行になりますので、これができないと思います。

答えて

0

ch()は、結果を待たずにチェーンを実行するだけです。 お待ちください。

ch = chain(scan_chunk.si([x.id for x in chunk]) for chunk in chunks)() 
return ch.get() 
関連する問題