2012-10-07 15 views
9

Ho trovato che il sedano supporta le catene di attività: http://celery.readthedocs.org/en/latest/userguide/canvas.html#chains.Eliminazione della catena di attività di Celery?

La domanda è: come posso interrompere l'esecuzione della catena in un'attività?

Ad esempio, abbiamo ottenuto una catena di N elementi (N> 2). E nel secondo compito ci rendiamo conto che non abbiamo bisogno che tutti i compiti di riposo siano eseguiti. Cosa fare?

+1

Che dire sollevare un'eccezione nell'attività quando si desidera interrompere? – RickyA

+0

suona bene :) proverò a –

+1

Ha funzionato? ... – RickyA

risposta

4

Nelle versioni più recenti di sedano (3.1.6) è possibile revocare un'intera catena semplicemente camminando sulla catena e revocando ogni oggetto a turno.

# Build a chain for results 
from tasks import addd 
from celery import chain 

def revoke_chain(result): 
    while result: 
     result.revoke() 
     result = result.parent 

# independent tasks (with immutable signatures) 
c = chain(*tuple(add.si(i,i) for i in xrange(50))) 
h = c() 

# some time later ... 
revoke_chain(h) 

# dependant task 
c = add.s(1,1) | add.s(2) | add.s(3) 
h = c() 

# some time later ... 
revoke_chain(h) 
Problemi correlati