赞
踩
这篇文章,主要介绍消息队列RabbitMQ之死信队列。
目录
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<String, Object> 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<String, Object> 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之死信队列。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。