栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 前沿技术 > 大数据 > 大数据系统

rabbitMQ死信.延迟队列

rabbitMQ死信.延迟队列

死信队列(延迟队列)
死信,在官网中对应的单词为 “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 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";
    }

 

 

 信息设了十秒过期

过期了会进入死信交换机 

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/748224.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号