RabbitMQ之死信(延迟)队列

目录

一、死信(延迟)队列介绍

        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、运行生产者,看测试结果

正常交换机:

有订单的正常交换机

 没有订单的正常交换机,说明时间已经过期,进入到死信交换机(没有进行编写消费者接收信息队列)

 今天的知识就分享到这,希望能够帮助到你!

  • 6
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值