zoukankan      html  css  js  c++  java
  • rabbitmq-高级(TTL过期时间)

    队列设置过期时间

    • 在生产者建TTL配置类
    @Configuration
    public class TTLRabbitmqConfiguration {
        //声明交换机
        @Bean
        public DirectExchange ttlDirectExchange(){
            return new DirectExchange("ttl_order_exchange",true,false);
        }
    
        //声明队列
        @Bean
        public Queue directTTLQueue(){
            Map<String,Object> map = new HashMap<>();
    		//这里一定是int,设置过期时间5s,5s后自动移除消息
            map.put("x-message-ttl",5000);
            return new Queue("ttl.direct.queue",true,false,false,map);
        }
    
        //完成交换机和队列绑定
        @Bean
        public Binding directTTLBinding(){
            return BindingBuilder.bind(directTTLQueue()).to(ttlDirectExchange()).with("ttl");
        }
    }
    
    • 测试类运行
    @Test
    void contextLoads3() {
       orderService.makeOrderTTL("1","1",12);
    }
    

    image

    • 打开rabbitmq
      可以看到ttl的队列已经生成,点进去队列可以看到Details中关于ttl过期时间的设置,然后再5s之后,该条消息自动消失
      image
      image
      image

    具体的消息设置过期时间

    • 配置类
    @Configuration
    public class TTLRabbitmqConfiguration {
        //声明交换机
        @Bean
        public DirectExchange ttlDirectExchange(){
    
            return new DirectExchange("ttl_order_exchange",true,false);
        }
    
        //声明队列 给队列设置过期时间
        @Bean
        public Queue directTTLQueue(){
            Map<String,Object> map = new HashMap<>();
            map.put("x-message-ttl",5000);//这里一定是int
            return new Queue("ttl.direct.queue",true,false,false,map);
        }
    
        //具体消息
        @Bean
        public Queue directTTLMessageQueue(){
            return new Queue("ttl.message.direct.queue",true);
        }
    
        //完成交换机和队列绑定
        @Bean
        public Binding directTTLBinding(){
            return BindingBuilder.bind(directTTLQueue()).to(ttlDirectExchange()).with("ttl");
        }
    
        @Bean
        public Binding directMsgBinding(){
            return BindingBuilder.bind(directTTLMessageQueue()).to(ttlDirectExchange()).with("ttlmessage");
        }
    }
    
    • 业务类
    public void makeOrderMessageTTL(String userId,String productId,int num){
    
        String orderId = UUID.randomUUID().toString();
        System.out.println("订单生成成功:" + orderId);
    
        String exchangeName = "ttl_order_exchange";
        String routingKey = "ttlmessage";
    
        MessagePostProcessor messagePostProcessor = new MessagePostProcessor() {
            @Override
            public Message postProcessMessage(Message message) throws AmqpException {
                message.getMessageProperties().setExpiration("5000");
                message.getMessageProperties().setContentEncoding("UTF-8");
                return message;
            }
        };
    
        //@param1 交换机 @param2 路由key/queue队列名称 @param3 消息内容
        rabbitTemplate.convertAndSend(exchangeName,routingKey,orderId,messagePostProcessor);
    }
    
    • 测试发送
    @Test
    void contextLoads4() {
        orderService.makeOrderMessageTTL("1","1",12);
    }
    

    image

    • 打开rabbitmq服务,可以看到队列生成,以及消息产生
      image
    • 5s后,消息自动消失,即移除
      image
  • 相关阅读:
    Unsupported major.minor version 52.0
    图片资源的加密和cocos2d-x中的解密
    python 生成器生成杨辉三角
    python非递归全排列
    一个对象合并的函数引发的错误
    什么是原生的javascript
    quick3.5 removeFromParent()导致的windows下模拟器崩溃问题
    this关键字和static关键字
    内存分析
    面向对象:类和对象
  • 原文地址:https://www.cnblogs.com/kaka-qiqi/p/14881948.html
Copyright © 2011-2022 走看看