目录
介绍
Dead Letter Exchange(DLX)和 Dead Letter Queue(DLQ)通常用于处理未被消费的消息或处理失败的消息。当某个消息不能被成功路由到队列中时,我们可以将该消息发送到 DLX 中,然后再将其路由到 DLQ 中进行处理。
使用 「Bean 」 配置死信队列
x-dead-letter-exchange
和x-dead-letter-routing-key
是 RabbitMQ 中常用的死信队列配置参数,可以将被拒绝或过期的消息重新发送到指定的队列和路由键中,以便进行处理。下面是一个基于 Java 的 RabbitMQ 的例子,演示如何通过设置
x-dead-letter-exchange
和x-dead-letter-routing-key
参数来实现死信队列。
@Configuration
public class SimpleQueueConfig {
Logger logger = LoggerFactory.getLogger(SimpleQueueConfig.class);
@Bean(name = "simpleQueue")
public Queue queue() {
Map<String, Object> arguments = new HashMap<>(4);
// 20秒内未被消费,则进入死信队列
arguments.put("x-message-ttl", 20000);
arguments.put("x-max-length", 1000);
arguments.put("x-dead-letter-exchange", "dead.exchange");
arguments.put("x-dead-letter-routing-key", "dead.message");
return new Queue("simple_queue", true, false, true, arguments);
}
@Bean(name = "deadQueue")
public Queue deadQueue() {
return new Queue("dead.queue", true, false, true);
}
@Bean(name = "deadExchange")
public Exchange exchange() {
return new DirectExchange("dead.exchange", true, true);
}
@Bean(name = "deadBinding")
public Binding binding() {
return BindingBuilder.bind(deadQueue()).to(exchange()).with("dead.message").noargs();
}
@RabbitListener(queues = "dead.queue")
public void readDeadMessage(String msg) {
logger.info("接收到的死信消息为:{}", msg);
}
// @RabbitListener(queues = "simple_queue")
// public void readMessage(String msg) {
// logger.info("one接收到的消息为:{}", msg);
// }
//
// @RabbitListener(queues = "simple_queue")
// public void readMessageTwo(String msg) {
// logger.info("two接收到的消息为:{}", msg);
// }
}
下面是
new Queue()
方法的各个参数的详解:
name
:要创建的队列的名称。该参数为必选参数,不能为空或 null 值。
durable
:是否将队列设置为持久化。持久化队列会将队列信息存储到磁盘上,即使 RabbitMQ 服务器停止运行或重启后也能够自动恢复队列。默认值为 false,表示不持久化。
exclusive
:是否将队列设置成排他性质的队列。排他队列只能被首次声明它的连接使用,并在连接关闭时自动删除。默认值为 false,表示不是排他队列。
autoDelete
:是否将队列设置为自动删除。即在最后一个消费者断开连接后,自动删除该队列。默认值为 false,表示不自动删除。
arguments
:用于设置其他参数的可选参数,可以传入 null 或 Map<String, Object> 类型的参数列表。常见的参数有:
x-message-ttl
:队列中消息的过期时间。单位为毫秒(ms)。例如,设置 x-message-ttl 为 10000 表示队列中的消息十秒钟后过期。
x-max-length
:队列允许存放最大消息数。例如,设置 x-max-length 为 100 表示队列中最多能存放 100 条消息。
x-max-length-bytes
:队列允许存放的最大字节数。例如,设置 x-max-length-bytes 为 1024 表示队列中最多能存放 1KB 的消息数据。
x-dead-letter-exchange
和x-dead-letter-routing-key
:用于设置死信队列,即当队列中的消息被拒绝或超时时将消息发送到指定的队列和路由键。
发送消息到simple_queue队列中,但是不去消费,让该队列的消息自动过期(此处设置的过期时间为20秒),进入死信队列中
模拟生产者发送消息①
@SpringBootTest(classes = MqApplication.class)
@RunWith(SpringRunner.class)
public class ProducerSimpleTest {
@Resource
RabbitTemplate rabbitTemplate;
@Test
public void sendDelayMessageByDirect() {
for (int i = 0; i < 10; i++) {
rabbitTemplate.convertAndSend("simple_queue", "简单队列!!!!!");
}
}
}
发送10条消息到simple_queue队列中,但是没有消费者去消费,消息设置的ttl时间为20秒,20秒都没有消费者去消费,那么则10条消息则进入死信队列中被死信消费者消费调