[rabbitmq-discuss] Ack'ing messages

Denny Swindle denny.swindle at gmail.com
Tue May 10 19:37:39 BST 2011


I'm trying to understand the CORRECT way of handling messages that cannot be processed, for some reason.  

I have two consumers listening for messages (in a worker queue setup, as described here: http://www.rabbitmq.com/tutorials/tutorial-two-python.html).

Scenario A:
A message is received and processed, then it's ack'd using basic_ack.

Scenario B:
A message is received and processed, but an error occurs.  An error like my consumer loses connection to the DB.  In this case, I don't issue a basic_ack (and my consumer remains running).

In looking at the docs, I understand if a message is not acknowledged and the consumer dies, rabbit will requeue the message for redelivery.  But what if the consumer remains running (and I just can't process the message).  Should I not issue the basic_ack (will it get sent to another consumer)?  Or should I issue the basic_ack and then reject the message?

I'm asking because earlier today I noticed I had an "unacknowledged" message on my queue.   With the unacknowledged message on the queue, only one worker consumer was receiving all messages.  

[root at web2 tmp]# rabbitmqctl list_queues -p / messages messages_unacknowledged messages_ready
Listing queues ...
1	1	0
0	0	0
0	0	0
0	0	0

The other worker was in a 'stale' state and not receiving any messages.  I'm just trying to understand if my logic on not ack'ing a message is correct and if that's how i ended up with an unacknowledged message.  Also trying to understand why my worker just stopped receiving messages.

Any guidance would be appreciated!

Thanks
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.rabbitmq.com/pipermail/rabbitmq-discuss/attachments/20110510/e394da77/attachment.htm>


More information about the rabbitmq-discuss mailing list