死信队列(延迟队列)
死信,在官网中对应的单词为
“Dead Letter”,
它是
RabbitMQ
的一种消息机制。
般来说,生产者将消息投递到
broker
或者直接到
queue
里了,
consumer
从
queue
取出消息进行消费,如果它一直无法消费某条数据,那么可以把这条消息放入死信队列里面。等待
条件满足了再从死信队列中取出来再次消费,从而避免消息丢失。
死信消息来源:
消息
TTL
过期
队列满了,无法再次添加数据
消息被拒绝(
reject
或
nack
),并且
requeue =false
在prvoider里面新建一个DeadConfig?
package com.smy.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
public class DeadConfig {
//1.需要正常的交换机
//2.正常队列发出信息(具备配置)
//3.具备死信交换机,队列
@Bean
public 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)
//死信routingkey
config.put("x-dead-letter-routing-key", "DD");//x-dead-letter-routing-key参数是给这个DLX指定路由键
return new Queue("normalQueue",true,false,false,config);
}
@Bean
public Queue deadQueue(){
return new Queue("deadQueue",true);
}
@Bean
public DirectExchange normalExchange(){
return new DirectExchange("normalExchange");
}
@Bean
public DirectExchange deadExchange(){
return new DirectExchange("deadExchange");
}
@Bean
public Binding normalbinding(){
return BindingBuilder.bind(normalQueue()).to(normalExchange()).with("CC");
}
@Bean
public Binding deadbinding(){
return BindingBuilder.bind(deadQueue()).to(deadExchange()).with("DD");
}
}
在coller里面新加个方法
@RequestMapping("/deadSend")
public String deadSend(String routingkey){
//保存了一个订单
template.convertAndSend("normalExchange","CC","order-1902");
return "yes";
}
?
?
?信息设了十秒过期
过期了会进入死信交换机?
|