RabbitMQ--死信队列
warning:
这篇文章距离上次修改已过190天,其中的内容可能已经有所变动。
死信队列(Dead Letter Queue)是RabbitMQ中一个特殊的队列,用于存储因消息无法被消费者成功处理而被重新投递的消息。当一个消息变成死信之后,可以将其放置到一个指定的队列中,方便后续进行处理。
在RabbitMQ中,死信的产生有以下几种情况:
- 消息被拒绝(basic.reject/basic.nack)并且requeue属性被设置为false。
- 消息的TTL(Time-To-Live)过期。
- 队列达到最大长度,旧的消息会变成死信。
下面是一个Python示例,演示如何使用死信队列:
import pika
# 连接到RabbitMQ服务器
connection = pika.BlockingConnection(pika.ConnectionParameters('localhost'))
channel = connection.channel()
# 声明一个普通队列和一个死信队列
channel.queue_declare(queue='normal_queue', durable=True)
channel.queue_declare(queue='dead_letter_queue', durable=True)
# 声明一个交换器和一个绑定关系,用于死信处理
channel.exchange_declare(exchange='dead_letter_exchange', exchange_type='direct')
channel.queue_bind(exchange='dead_letter_exchange', queue='dead_letter_queue', routing_key='dead_letter_routing_key')
# 设置队列参数,包括死信交换器和路由键
queue_args = {
'x-dead-letter-exchange': 'dead_letter_exchange',
'x-dead-letter-routing-key': 'dead_letter_routing_key',
'x-message-ttl': 10000, # 设置消息的TTL
'x-max-length': 10, # 设置队列的最大长度
}
# 声明一个带有死信处理的队列
channel.queue_declare(queue='test_queue', durable=True, arguments=queue_args)
# 发送一条消息到test_queue,它会在TTL过期或队列满后变成死信
channel.basic_publish(exchange='',
routing_key='test_queue',
body='Hello World!',
properties=pika.BasicProperties(
delivery_mode=2, # 设置消息持久化
))
# 接收死信消息
def callback(ch, method, properties, body):
print(f"Received dead letter: {body}")
channel.basic_consume(queue='dead_letter_queue', on_message_callback=callback, auto_ack=True)
print("Waiting for messages. To exit press CTRL+C")
channel.start_consuming()
在这个例子中,我们创建了一个名为test_queue
的队列,它有一个TTL和一个最大长度限制,并且配置了当这些条件被触发时,消息会被发送到名为dead_letter_queue
的死信队列。我们还创建了一个死信交换器dead_letter_exchange
和绑定关系,指定了死信消息的路由键。当test_queue
中的消息变成死信时,它们将被发送到dead_letter_queue
,并由回调函数callback
进行处理。
评论已关闭