Ensuring message delivery with the mandatory flagΒΆ
The following example demonstrates how to check if a message is delivered by setting the mandatory flag and handling exceptions when using the BlockingConnection:
import pika
import pika.exceptions
# Open a connection to RabbitMQ on localhost using all default parameters
connection = pika.BlockingConnection()
# Open the channel
channel = connection.channel()
# Declare the queue
channel.queue_declare(queue="test", durable=True, exclusive=False, auto_delete=False)
# Enabled delivery confirmations. This is REQUIRED.
channel.confirm_delivery()
# Send a message
try:
channel.basic_publish(exchange='test',
routing_key='test',
body='Hello World!',
properties=pika.BasicProperties(content_type='text/plain',
delivery_mode=1),
mandatory=True)
print('Message was published')
except pika.exceptions.UnroutableError:
print('Message was returned')