I am using rabbitmq
to communicate between microservices
written in ruby on rails. Each service subscribes to a topic
. All services are scaled
and run as multiple instances based on need.
During subscription bunny
moves all the messages
from the queue into unacked
state. This makes other scaled instances to be just idle, since there is no message in ready
state.
Is there a way to limit the number of messages a subscription can fetch, so that other instances can take the remaining messages from the queue.
Based on the information you made available, I'm assuming you're using rubybunny. If this assumption is incorrect (there are other ruby clients available for rabbitmq) let me know and/or check the documentation related to your client.
Back to rubybunny, link provided points to necessary information, quoting it: