RabbitMQ之死信(延迟)队列

目录

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

        1、死信交换机概述:

        2、死信案列讲解

二、死信交换机代码编写

         1、编写死信交换机配置类

         2、编写死信控制类

         3、运行生产者,看测试结果


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

        1、死信交换机概述:

死信交换机(DLXs)就是普通的交换机,可以是任何一种类型,也可以用普通常用的方式进行声明。

对于任何一个队列,死信交换机可以通过在客户端使用队列参数进行声明,或者是在服务器使用policy命令进行声明创建。当同时使用这两种方式声明一个死信交换机时,队列参数声明的方式将被优先使用。

使用policy命令配置死信交换机的方式被推荐使用,因为该方式不会因为应用的重新部署而重新配置。

         RabbitMQ之死信(延迟)队列_第1张图片

        2、死信案列讲解

以订单超时为例:

RabbitMQ之死信(延迟)队列_第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 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、运行生产者,看测试结果

正常交换机:

有订单的正常交换机

RabbitMQ之死信(延迟)队列_第3张图片

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

RabbitMQ之死信(延迟)队列_第4张图片

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

你可能感兴趣的:(RabbitMQ,rabbitmq,分布式,java)