SpringBoot 整合RabbitMQ 之延迟队列实验

在Spring Boot中整合RabbitMQ并实现延迟队列的功能,可以按照以下步骤进行:

  1. 添加依赖:在pom.xml文件中添加RabbitMQ和Spring AMQP相关的依赖。
java 复制代码
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-amqp</artifactId>
</dependency>
  1. 配置RabbitMQ连接信息:在application.properties或application.yml文件中配置RabbitMQ的连接信息,包括host、port、username、password等。
java 复制代码
spring.rabbitmq.host=127.0.0.1
spring.rabbitmq.port=5672
spring.rabbitmq.username=guest
spring.rabbitmq.password=guest
  1. 创建消息发送者:创建一个消息发送者类,用于发送消息到RabbitMQ。
java 复制代码
import org.springframework.amqp.core.AmqpTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;

@Component
public class MessageSender {
    
    @Autowired
    private AmqpTemplate amqpTemplate;
    
    public void sendMessage(String message, long delayTime) {
        amqpTemplate.convertAndSend("exchangeName", "routingKey", message, message -> {
            message.getMessageProperties().setDelay((int) delayTime);
            return message;
        });
    }
}
  1. 创建消息接收者:创建一个消息接收者类,用于监听RabbitMQ中的消息。
java 复制代码
import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.stereotype.Component;

@Component
public class MessageReceiver {
    
    @RabbitListener(queues = "queueName")
    public void receiveMessage(String message) {
        System.out.println("Received message: " + message);
    }
}
  1. 创建延迟队列配置类:创建一个延迟队列的配置类,用于声明交换机、队列和绑定关系。
java 复制代码
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 DelayedQueueConfig {
    
    @Bean
    public Queue queue() {
        return new Queue("queueName");
    }
    
    @Bean
    public CustomExchange exchange() {
        Map<String, Object> args = new HashMap<>();
        args.put("x-delayed-type", "direct");
        return new CustomExchange("exchangeName", "x-delayed-message", true, false, args);
    }
    
    @Bean
    public Binding binding(Queue queue, CustomExchange exchange) {
        return BindingBuilder.bind(queue).to(exchange).with("routingKey").noargs();
    }
}

以上步骤完成后,就实现了Spring Boot与RabbitMQ的整合,并且可以使用延迟队列发送和接收消息。在发送消息时,通过设置delayTime参数来设置消息的延迟时间。在接收消息时,通过@RabbitListener注解来监听指定的队列,并处理接收到的消息。

相关推荐
学习3人组7 小时前
业务主表+JSON自定义字段
java·spring boot·json
吕永强8 小时前
基于SpringBoot+Vue宠物领养系统的设计与实现(源码+论文+部署)
spring boot·毕业设计·毕业论文·宠物领养·宠物领养系统
yoyo_zzm9 小时前
PHP vs Java:后端语言终极选择指南
java·spring boot·后端·架构·php
鱼鳞_10 小时前
苍穹外卖-Day01(开发环境搭建)
java·spring boot·spring·maven
学不思则罔10 小时前
SpringBoot启动失败排查指南
spring boot·后端·部署
夕除10 小时前
spring boot 5
数据库·spring boot·后端
yoyo_zzm11 小时前
ThinkPHP1.X核心特性解析
数据库·spring boot·nginx
hexu_blog11 小时前
前端vue后端java+springboot如何实现pdf,word,excel之间的相互转换
java·前端·vue.js·spring boot·文档转换
倒流时光三十年11 小时前
第9篇 消息不丢:三端协同防丢失方案
spring boot·kafka
Devin~Y12 小时前
大厂Java面试实录:Spring Boot/WebFlux、JVM调优、Redis/Kafka、Spring Cloud 与 RAG/Agent 追问
java·jvm·spring boot·maven·mybatis·jpa·spring webflux