RabbitMQ的死信队列

1.死信的概念

死信简单理解就是因为种种原因,无法被消费的消息.

有死信自然就有死信队列,消息再一个队列中编程死信之后,它能被重新发送到另一个交换器中,这个交换器就是DLX,绑定DLX的队列,就被称为死信队列,简称DLQ

消息变成死信一般由于一下几种情况:

1.消息被拒绝

2.消息过期

3.队列达到最大长度 

1.2正常队列绑定死信交换机

retrn QueueBuilder.durable(Constant.NORMAL_QUEUE)
 .deadLetterExchange(Constant.DLX_EXCHANGE_NAME)
 .deadLetterRoutingKey("dlx").build();

当这个队列存在死信时,RabbitMQ会自动把这个消息重新发布到设置的DLX上,进而被路由到死信队列上。 

1.3死信队列的应用场景

  • 消息重试:将死信消息重新发送到原队列或另一个队列进行重试处理,比如,在一个支付系统中,支付结果通知消息可能因为网络问题无法被支付回调服务及时消费,那么可以将该消息放入死信队列,稍后再进行重试,直到消费成功。
  • 消息丢弃:直接丢弃这些无法处理的消息,以避免他们占用系统资源
  • 日志收集:将私信消息作为日志收集起来,用于后续分析和问题定位
  • 例如,一个电商系统中,订单处理服务在消费订单消息时,如果因为库存不足无法完成订单处理,那么该订单消息就可以被发送到死信队列中,等待人工介入或者后续的库存补充后再进行处理

### 配置和使用RabbitMQ死信队列 #### 创建死信交换机与队列 为了使消息能够被转发至死信队列,在创建常规队列时需指定特定参数来关联死信交换机及其路由键。这可以通过编程方式完成,例如在Java Spring Boot环境中: ```java @Bean(name = "deadExchange") public TopicExchange deadExchange() { return ExchangeBuilder.topicExchange("DEAD_EXCHANGE").durable(true).build(); } @Bean(name = "deadQueue") public Queue deadQueue() { Map<String, Object> args = new HashMap<>(); args.put("x-dead-letter-exchange", "DEAD_EXCHANGE"); args.put("x-dead-letter-routing-key", "DEAD_ROUTING_KEY"); return QueueBuilder.durable("DEAD_QUEUE").withArguments(args).build(); } ``` 上述代码片段展示了如何通过`@Bean`注解定义死信交换机以及带有额外参数的死信队列[^4]。 #### 绑定关系设置 接着需要建立正常的交换机、队列同死信机制之间的联系。对于每一个可能产生死信的消息队列而言,应该设定相应的绑定规则以便于当条件满足时可以将这些未成功消费的消息重定向给预设好的死信队列: ```java @Bean public Binding normalBinding(DirectExchange directExchange, Queue normalQueue) { // 正常情况下使用的binding... // 设置该队列产生的死信会被发送到哪个exchange/routing key Map<String, Object> arguments = new HashMap<>(); arguments.put("x-dead-letter-exchange", "DEAD_EXCHANGE"); arguments.put("x-dead-letter-routing-key", "DEAD_ROUTING_KEY"); return BindingBuilder.bind(normalQueue) .to(directExchange) .with("NORMAL_ROUTING_KEY") .arguments(arguments); } ``` 此部分逻辑同样适用于其他类型的交换模式(如topic,fanout等),只需调整具体的匹配模式即可[^1]。 #### 处理死信 一旦消息变为死信并到达对应的死信队列之后,则可以根据业务需求对其进行适当的操作,比如记录日志、尝试再次投递给原始队列或者其他形式的数据持久化操作[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值