RabbitMQ之死信队列
什么是死信队列呢?死信队列有什么用呢?
死信队列:
从字面意思上我们可以理解为在队列中死亡的消息;
官方的定义为:当消息在一个队列中变成死信之后,它能被重新发送到另一个交换机中,这个交换机就是DLX,绑定DLX的队列就称之为死信队列;
DLX:全称Dead-Letter-Exchange,称为死信交换机。
那么在什么情况下消息会死信呢?
1、当消息被拒绝的时候;
2、当消息过期的时候;
3、队列达到最大长度的时候;
例子:假如你在某平台下单了之后需要在规定的时间内完成相对应的操作。如果在规定的时间内你没完成,那么这个订单就过期了,也就是说变成了死信消息。
那么死信队列又有什么用呢?
用于处理过期,或者异常的消息,具体的话根据业务需求来处理。
如何使用死信队列
Spring Boot 的实现方式
@Component
public class RabbitMQConfig {
//创建交换机
@Bean(name = "topi-exchange")
public TopicExchange getExchange(){
return new TopicExchange("topi-exchange", true, false);
}
//创建队列
@Bean(name = "topi-queue")
public Queue getQueue(){
Map<String, Object> args = new HashMap<>();
args.put("x-message-ttl",60000); // 定义过期时间
args.put("x-dead-letter-exchange", "dead-exchange"); // 与交换机产生关联
args.put("x-dead-letter-routing-key","*.dead.*"); // 路由规则
return new Queue("topi-queue", true, false, false,args);
}
//绑定队列
@Bean
public Binding topiBinding(@Qualifier("topi-exchange") TopicExchange topicExchange, @Qualifier("topi-queue") Queue queue){
return BindingBuilder.bind(queue).to(topicExchange).with("*.topi.*");
}
//创建死信MQ
//创建交换机
@Bean(name = "dead-exchange")
public TopicExchange deadExchange(){
return new TopicExchange("dead-exchange", true, false);
}
//创建队列
@Bean(name = "dead-queue")
public Queue deadQueue(){
return new Queue("dead-queue", true, false, false);
}
//绑定队列
@Bean
public Binding deadBinding(@Qualifier("dead-exchange") TopicExchange topicExchange, @Qualifier("dead-queue") Queue queue){
return BindingBuilder.bind(queue).to(topicExchange).with("*.dead.*");
}
}
工程未启动前级交换机以及队列的状态
启动后的状态
由上图我们可以看到,我们在启动工程之后,相应的交换机跟队列已经自动创建好了,且也看到消息先发送到死信队列上,等消息过期了再转到接盘的队列,对于死信消息我们只需监听“dead-queue”队列,然后根据不同的业务需求对死信消息进行一个集中处理。