这篇文章,主要介绍消息队列RabbitMQ之死信队列。
目录
一、RabbitMQ死信队列
1.1、什么是死信队列
1.2、设置过期时间TTL
1.3、配置死信交换机和死信队列(代码配置)
(1)设置队列过期时间
(2)设置单条消息过期时间
(3)队列设置死信交换机
(4)配置的基本思路
1.4、配置死信交换机和死信队列(RabbitMQ管理界面配置)
在RabbitMQ中,并没有提供真正意义上的延迟队列,但是RabbitMQ可以设置队列、消息的过期时间,当队列或者消息到达过期时间之后,还没有被消费者消费,那么RabbitMQ会将这些消息放入另外一个队列,这个队列叫做:死信队列,而这个过期的消息就叫做:死信消息。
哪些情况下,消息会变成死信消息???
死信队列需要通过一个死信交换机来分发死信消息,死信交换机是Dead Letter Exchange,简称:DLX。死信队列大致原理图如下所示:
RabbitMQ可以给Queue队列设置过期时间,也可以给单独的某一条消息Message设置过期时间,过期时间就是指消息存活时间,英文全称是Time To Live,简称:TTL。
注意:可以同时设置队列和消息的过期时间,RabbitMQ会根据最短的时间来决定消息是否已经过期了。
死信交换机和死信队列和普通的交换机、队列没有什么不同,只是叫法不同,在配置死信交换机和死信队列的时候,只需要给具体的业务队列配置死信交换机,然后给这个死信交换机绑定一个死信队列即可。
可以通过代码设置死信交换机和死信队列,也可以通过RabbitMQ提供的管理界面直接配置死信交换机和死信队列。在实际开发中,交换机和队列都是事先创建好的,之后生产者、消费者直接从指定的队列消费消息即可。
在声明队列的时候,给队列设置【x-message-ttl】属性即可。
// 6、指定需要操作的消息队列,如果队列不存在,则会创建
String queueName = "queue_demo_2023";
Map arguments = new HashMap<>();
arguments.put("x-message-ttl", "30000"); // 设置队列的过期时间
channel.queueDeclare(queueName, false, false, false, arguments);
在生产者发送消息的时候,通过【AMQP.BasicProperties】设置过期时间属性。
// 6、发送消息
String message = "RabbitMQ死信队列案例";
// TODO 设置消息的属性
AMQP.BasicProperties properties = new AMQP.BasicProperties.Builder()// 设置消息的过期时间是:30秒.expiration("30000").build();
channel.basicPublish(exchangeName, "demo_key_2023", properties, message.getBytes());
// 声明 Exchange,如果不存在,则会创建
channel.exchangeDeclare("exchange_demo_2023", "direct");
// TODO 声明死信交换机
channel.exchangeDeclare("exchange_dead_2023", "direct");// 指定需要操作的消息队列,如果队列不存在,则会创建
// TODO 设置队列过期时间【业务队列】
Map arguments = new HashMap<>();
arguments.put("x-message-ttl", 10000); // 设置队列的过期时间
// 指定队列绑定的死信交换机名称
arguments.put("x-dead-letter-exchange", "exchange_dead_2023");
// 指定死信交换机的路由键routingKey
arguments.put("x-dead-letter-routing-key", "dead_key_2023");
channel.queueDeclare("queue_demo_2023", false, false, false, arguments);
// TODO 创建死信队列
channel.queueDeclare("queue_dead_2023", false, false, false, null);// 绑定 Exchange 和 Queue
channel.queueBind("queue_demo_2023", "exchange_demo_2023", "demo_key_2023");
// TODO 死信队列绑定死信交换机
channel.queueBind("queue_dead_2023", "exchange_dead_2023", "dead_key_2023");
到此,RabbitMQ中的死信队列就介绍完啦。
综上,这篇文章结束了,主要介绍消息队列RabbitMQ之死信队列。