We have a distributed architecture based on rabbitMQ
and Celery
.
We can launch in parallel multiple tasks without any issue. The scalability is good.
Now we need to control the task remotely: PAUSE, RESUME, CANCEL. The only solution we found is to make in the Celery task a RPC call to another task that replies the command after a DB request. The Celery task and RPC task are not on the same machine and only the RPC task has access to the DB.
Do you have any advice how to improve it and easily communicate with an ongoing task? Thank you
EDIT:
In fact we would like to do something like in the picture below. It's easy to do the Blue
configuration or the Orange
, but we don't know how to do both simultaneously.
Workers are subscribing to a common Jobs queue
and each worker has its own Admin queue
declared on an exchange.
EDIT:
IF this is not possible with Celery
, I'am open to a solution with other frameworks like python-rq
.