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

rabbitmq延迟队列的实现

rabbitmq延迟队列的实现

第一步:下载延迟队列插件

去https://github.com/rabbitmq/rabbitmq-delayed-message-exchange/tree/v3.9.x中下载对应版本的插件

第二步:安装

执行 rabbitmq-plugins enable rabbitmq_delayed_message_exchange 命令,rabbitmq需重启

第三步:pom文件导入

    com.rabbitmq
    amqp-client


    org.springframework.amqp
    spring-rabbit

第四步 :创建交换机并绑定延迟队列
package com.flexible.yiren.user.rabbitmq;


import org.springframework.amqp.core.Binding;
import org.springframework.amqp.core.BindingBuilder;
import org.springframework.amqp.core.CustomExchange;
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 RabbitConfig {
    public static final String DELAY_EXCHANGE = "delay.exchange";

    public static final String DELAY_ROUTE_KEY = "delay.routeKey";

    public static final String DELAY_QUEUE = "delay.queue";

    
    @Bean
    public CustomExchange delayExchange() {
        Map arguments = new HashMap<>(1);
        arguments.put("x-delayed-type", "direct");
        return new CustomExchange(DELAY_EXCHANGE,"x-delayed-message",true,false,arguments);
    }

    
    @Bean
    public Queue delayQueue() {
        return new Queue(DELAY_QUEUE,true,false,false);
    }

    
    @Bean
    public Binding delayBind() {
        return BindingBuilder.bind(this.delayQueue()).to(this.delayExchange()).with(DELAY_ROUTE_KEY).noargs();
    }

}
 第五步:创建一个监听队列的方法
package com.flexible.yiren.user.rabbitmq;

import com.rabbitmq.client.Channel;
import org.springframework.amqp.core.Message;
import org.springframework.amqp.rabbit.annotation.RabbitHandler;
import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;

import java.io.IOException;

@Component
public class CouponHandler {


    @RabbitHandler
    @RabbitListener(queues = RabbitConfig.DELAY_QUEUE)
    public void delayConsumer(Message message) {
        System.out.println("-------"+new String(message.getBody()));
    }


}
 第六步:发送内容
package com.flexible.yiren.user.contorller;


import org.springframework.amqp.core.*;
import org.springframework.amqp.rabbit.core.RabbitTemplate;


@RestController
public class CouponsController {


    private final RabbitTemplate rabbitTemplate;
    
    @GetMapping("test")
    @ApiOperation("测试")
    public void test() {
        rabbitTemplate.convertAndSend(RabbitConfig.DELAY_EXCHANGE, RabbitConfig.DELAY_ROUTE_KEY, "需要发送的消息内容", msg -> {
            msg.getMessageProperties().setHeader("x-delay", 2 * 1000);//延迟两秒接收
            return msg;
        });

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

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

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