Sto eseguendo Django, Celery e RabbitMQ. Quello che sto cercando di realizzare è quello di garantire che le attività relative ad un utente vengono eseguiti in ordine (in particolare, uno alla volta, non voglio compito concorrenza per utente)Come garantire l'ordine di esecuzione dell'attività per utente utilizzando Celery, RabbitMQ e Django?
- ogni volta che viene aggiunto nuovo compito per l'utente, dovrebbe dipendere dall'ultima operazione aggiunta. Funzionalità aggiuntive potrebbero includere l'aggiunta di attività alla coda, se l'attività di questo tipo è in coda per questo utente e non è ancora stata avviata.
Ho fatto qualche ricerca e:
- non riuscivo a trovare un modo per collegare compito appena creato con già in coda uno in Sedano sé, catene sembrano essere in grado di collegare nuovi compiti solo .
- Penso che entrambe le funzionalità siano possibili da implementare con il gestore di messaggi RabbitMQ personalizzato, anche se potrebbe essere difficile codificarlo dopo tutto.
- Ho anche letto su celery-tasktree e questo potrebbe essere un modo più semplice per garantire l'ordine di esecuzione, ma come faccio a collegare la nuova attività con già "
applied_async
" task_tree o coda? Esiste un modo per implementare questa funzionalità aggiuntiva non duplicata utilizzando questo pacchetto?
Edit: C'è questo anche questo "blocco" esempio in celery cookbook e come il concetto va bene, non riesco a vedere un possibile modo per farlo funzionare come previsto nel mio caso - semplicemente se non ci riesco acquisire il blocco per l'utente, il compito dovrebbe essere ripetuto, ma questo significa spingerlo fino alla fine della coda.
Quale sarebbe la migliore linea d'azione qui?
Suppongo che tu non sappia quali sono le attività per un particolare utente prima di inserire l'attività? –
Perché non creare una coda da soli (per utente) e fare in modo che Celery esegua le attività da lì? – trinchet