目录
一、死信(延迟)队列介绍
? ? ? ? 1、死信交换机概述:
? ? ? ? 2、死信案列讲解
二、死信交换机代码编写
? ? ? ? ?1、编写死信交换机配置类
? ? ? ? ?2、编写死信控制类
? ? ? ? ?3、运行生产者,看测试结果
一、死信(延迟)队列介绍
? ? ? ? 1、死信交换机概述:
死信交换机(DLXs)就是普通的交换机,可以是任何一种类型,也可以用普通常用的方式进行声明。
对于任何一个队列,死信交换机可以通过在客户端使用队列参数进行声明,或者是在服务器使用policy命令进行声明创建。当同时使用这两种方式声明一个死信交换机时,队列参数声明的方式将被优先使用。
使用policy命令配置死信交换机的方式被推荐使用,因为该方式不会因为应用的重新部署而重新配置。
? ? ? ? ?
? ? ? ? 2、死信案列讲解
以订单超时为例:
?
二、死信交换机代码编写
注意死信交换机就是一台普通的交换机
生成一台死信交换机的几大具备点:
* 1、需要正常的交换机
* 2、正常队列发出消息
* 3、具备死信交换机
? ? ? ? ?1、编写死信交换机配置类
1、声明一个正常队列、交换机以及路由键
2、声明一个死信队列、死信交换机以及死信路由键
package com.zj.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 DeadQueueConfig {
/**
* 1、需要正常的交换机
* 2、正常队列发出消息
* 3、具备死信交换机
*
*/
@Bean
public Queue normalQueue(){
Map<String,Object> config=new HashMap<>();
//1、过期时间
config.put("x-message-ttl", 10000);//message在该队列queue的存活时间最大为10秒
//2、死信交换机
config.put("x-dead-letter-exchange", "deadExchange"); //x-dead-letter-exchange参数是设置该队列的死信交换器(DLX)
//3、要找到死信队列,必须要死信路由键
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 deadQueueA(){
return new Queue("deadQueueA",true);
}
@Bean
public DirectExchange normalExchange(){
return new DirectExchange("normalExchange");
}
@Bean
public DirectExchange deadExchange(){
return new DirectExchange("deadExchange");
}
@Bean
public Binding normalbindding(){
return BindingBuilder.bind(normalQueue()).to(normalExchange()).with("PP");
}
@Bean
public Binding deadbindding(){
return BindingBuilder.bind(deadQueueA()).to(deadExchange()).with("DD");
}
}
? ? ? ? ?2、编写死信控制类
@RequestMapping("/sendDead")
public String sendDead() {
rabbitTemplate.convertAndSend("normalExchange", "PP" ,"order-1902");
return "yes";
}
? ? ? ? ?3、运行生产者,看测试结果
正常交换机:
有订单的正常交换机
?没有订单的正常交换机,说明时间已经过期,进入到死信交换机(没有进行编写消费者接收信息队列)
?今天的知识就分享到这,希望能够帮助到你!
|