- 队列)的概念

">一、死信交换机(延迟队列)的概念 

- 二、死信交换机(代码)
一、死信交换机(延迟队列)的概念 

死信,在官网中对应的单词为“Dead Letter”,它是 RabbitMQ 的一种消息机制。
般来说,生产者将消息投递到 broker 或者直接到 queue 里了,consumer 从 queue 取出消息进行消费,如果它一直无法消费某条数据,那么可以把这条消息放入死信队列里面。等待
条件满足了再从死信队列中取出来再次消费,从而避免消息丢失。
死信消息来源:
- 消息 TTL 过期
- 队列满了,无法再次添加数据
- 消息被拒绝(reject 或 nack),并且 requeue =false
二、死信交换机(代码)
①生产者,创建交换机
package com.xhy.provider.mq;import org.springframework.amqp.core.Binding;import org.springframework.amqp.core.BindingBuilder;import org.springframework.amqp.core.DirectExchange;import org.springframework.amqp.core.Queue;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import java.util.HashMap;import java.util.Map;@Configuration@SuppressWarnings("all")public class DeadConfig {/*** 死信交换机需要:* 1.需要正常的交换机* 2.正常的队列* 3.具备死信交换机和队列**///新建队列//正常@Beanpublic Queue normalQueue(){Map<String,Object> config=new HashMap<>();//过期时间config.put("x-message-ttl", 10000);//message在该队列queue的存活时间最大为10秒//死信交换机config.put("x-dead-letter-exchange", "deadExchange"); //x-dead-letter-exchange参数是设置该队列的死信交换器(DLX)//死信routingkeyconfig.put("x-dead-letter-routing-key", "deadQueue");//x-dead-letter-routing-key参数是给这个DLX指定路由键return new Queue("normalQueue",true,false,false,config);}//死信@Beanpublic Queue daadQueue(){return new Queue("daadQueue",true);}//创建交换机---正常(死信交换机就是直连交换机)@Beanpublic DirectExchange normalExchange(){return new DirectExchange("directExchange");}//死信@Beanpublic DirectExchange deadExchange(){return new DirectExchange("deadExchange");}//进行交换机和队列的绑定//设置绑定key//正常@Beanpublic Binding normalBinding(){return BindingBuilder.bind(normalQueue()).to(normalExchange()).with("CC");}//死信@Beanpublic Binding deadBinding(){return BindingBuilder.bind(normalQueue()).to(deadExchange()).with("DD");}}
