死信:无法被消费的消息,称为死信。
如果死信一直留在队列中,会导致一直被消费,却从不消费成功,专门有一个存放死信的队列,称为死信队列(DDX, dead-letter-exchange)。
死信的几种来源:
消息TTL过期(time to live,存活时间,可以用在限时支付消息)
队列达到最大长度(队列满了,无法路由到该队列)
消息被拒绝(basic.reject / basic.nack),并且requeue = false

准备环境配置
准备MQ的队列和环境
正常交换机
★正常队列(最长队列5) ----正常消费者,拒绝消息
★tt队列(过期时间60秒) ----没有消费者
死信交换机
★死信队列
主要配置文件如下:
@Configuration
public class DeadConfig {
/* 正常配置 **********************************************************************************************************/
/**
* 正常交换机,开启持久化
*/
@Bean
DirectExchange normalExchange() {
return new DirectExchange("normalExchange", true, false);
}
@Bean
public Queue normalQueue() {
// durable: 是否持久化,默认是false,持久化队列:会被存储在磁盘上,当消息代理重启时仍然存在,暂存队列:当前连接有效
// exclusive: 默认也是false,只

本文介绍了如何在SpringBoot应用中利用RabbitMq创建和管理死信队列,包括消息TTL过期、队列达到最大长度以及消息被拒绝时的情况。通过配置死信交换机和死信队列,确保了无法消费的消息能够被正确处理。文中还展示了相关的Java代码示例和MQ控制台截图。
最低0.47元/天 解锁文章
50万+

被折叠的 条评论
为什么被折叠?



