Java实战:Spring Boot集成AMQP协议的RabbitMQ实现消息队列

随着微服务架构在现代软件开发中的广泛应用,异步处理和解耦通信成为了提升系统性能与稳定性的关键。作为AMQP(Advanced Message Queuing Protocol)协议的优秀实现,RabbitMQ以其高性能、易用性以及丰富的功能赢得了开发者们的青睐。本文将带领大家深入了解如何在Spring Boot项目中无缝集成RabbitMQ,实现高效的消息传递。

一、RabbitMQ与Spring Boot简介

RabbitMQ 是一个开源且高度可扩展的消息中间件,支持多种消息协议,其中最为广泛使用的是AMQP协议。通过消息队列,各个服务之间可以异步、松耦合地进行数据交换,从而提高系统的弹性和并发处理能力。

Spring Boot 则是一款简化新Spring应用初始搭建及开发过程的框架,内置了对RabbitMQ的良好支持,通过spring-boot-starter-amqp依赖即可快速实现与RabbitMQ的集成。

二、Spring Boot集成RabbitMQ步骤详解

1. 添加依赖

在项目的pom.xml或build.gradle文件中引入Spring Boot对RabbitMQ的支持:

<!-- Maven -->
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-amqp</artifactId>
</dependency>

或者

// Gradle
implementation 'org.springframework.boot:spring-boot-starter-amqp'
2. 配置RabbitMQ连接

在application.properties或application.yml配置文件中添加RabbitMQ服务器连接信息:

# application.properties
spring.rabbitmq.host=localhost
spring.rabbitmq.port=5672
spring.rabbitmq.username=guest
spring.rabbitmq.password=guest
3. 创建消息生产者与消费者
  • 消息生产者 使用@RabbitListener注解监听某个通道,并通过RabbitTemplate发送消息到指定队列。
import org.springframework.amqp.core.Queue;
import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;@Component
public class MessageProducer {@Autowiredprivate RabbitTemplate rabbitTemplate;// 假设已经定义了一个Queue bean@Autowiredprivate Queue myQueue;public void sendMessage(String message) {rabbitTemplate.convertAndSend(myQueue.getName(), message);}// 可以设置一个RabbitListener来接收其他服务返回的消息@RabbitListener(queues = "${my.reply.queue.name}")public void receiveReplyMessage(String reply) {System.out.println("Received reply: " + reply);}
}
  • 消息消费者 使用@RabbitListener注解监听队列,并处理接收到的消息。
import org.springframework.amqp.rabbit.annotation.RabbitHandler;
import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.stereotype.Component;@Component
public class MessageConsumer {@RabbitListener(queues = "myQueue")@RabbitHandlerpublic void handleMessage(String message) {System.out.println("Received message from queue: " + message);// 在这里执行业务逻辑...}
}
4. 定义队列与交换器

在Spring Boot应用启动时,可以通过代码或配置文件声明并绑定队列和交换器:

@Configuration
public class RabbitConfig {@Beanpublic Queue myQueue() {return new Queue("myQueue", true); // 声明持久化队列}@Beanpublic DirectExchange myExchange() {return new DirectExchange("myExchange");}@Beanpublic Binding binding(Queue myQueue, DirectExchange myExchange) {return BindingBuilder.bind(myQueue).to(myExchange).with("routing.key"); // 绑定队列到交换器}
}

三、高级特性与应用场景

  • 消息确认机制:启用publisher confirms确保消息已正确投递至RabbitMQ。
  • 死信队列与TTL:为防止消息堆积或过期,可以设置消息有效期(TTL)并在其过期后转发至死信队列。
  • 发布/订阅模式:利用交换器(如FanoutExchange)实现一对多的消息广播。
  • 路由模式:根据消息携带的路由键,通过DirectExchange或TopicExchange精确或模糊匹配路由消息至多个队列。

四、实战案例分析

假设我们有一个订单处理服务,当用户下单成功后需要异步通知库存服务减库存:

  1. 订单服务创建一个OrderPlacedEvent对象,并将其序列化为JSON格式,然后通过RabbitTemplate发送至名为order-events的队列。
  2. 库存服务订阅这个队列,并使用MessageConverter反序列化消息,调用相应方法更新库存。
// 订单服务 - 生产者
@Service
public class OrderService {@Autowiredprivate RabbitTemplate rabbitTemplate;@Autowiredprivate ObjectMapper objectMapper;public void placeOrder(Order order) {// ... 执行订单相关操作 ...// 构建事件对象OrderPlacedEvent event = new OrderPlacedEvent(order.getId(), order.getQuantity());// 将事件转换为JSON字符串并发送String jsonEvent = objectMapper.writeValueAsString(event);rabbitTemplate.convertAndSend("order-events", "", jsonEvent);}
}// 库存服务 - 消费者
@Component
public class InventoryConsumer {@RabbitListener(queues = "order-events")public void handleOrderPlacedEvent(@Payload String jsonEvent, @Header(AmqpHeaders.DELIVERY_TAG) long tag) {try {// 反序列化事件OrderPlacedEvent event = objectMapper.readValue(jsonEvent, OrderPlacedEvent.class);// 调用库存管理方法decreaseInventory(event.getItemId(), event.getQuantity());// 确认消息消费channel.basicAck(tag, false);} catch (IOException e) {// 处理异常,可能需要拒绝消息等操作}}
}

五、总结

通过Spring Boot集成RabbitMQ,我们可以轻松构建出基于AMQP协议的高效、可靠的分布式消息系统。同时,结合Spring Boot的自动配置与强大的扩展性,能够快速应对各种复杂的业务场景,有效提升系统的整体性能和稳定性。实际项目中,还需结合具体业务需求调整和优化消息模型、错误处理策略以及集群部署方案等细节。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/709990.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SpringBoot之自定义注解及Java反射机制实现对实体类某些字段记录日志的功能

SpringBoot之自定义注解及Java反射机制实现对实体类某些字段记录日志的功能 文章目录 SpringBoot之自定义注解及Java反射机制实现对实体类某些字段记录日志的功能1. 使用场景2. 实现思路3. 具体实现1. 定义注解类2. 日志实体类3. 反射操作工具类4. 定义记录日志的工具类5. 业务…

江科大stm32学习笔记——【5-2】对射式红外传感器计次旋转编码计次

一.对射式红外传感器计次 1.原理 2.硬件连接 3.程序 CountSensor.c: #include "stm32f10x.h" // Device header #include "Delay.h"uint16_t CountSensor_Count;void CountSensor_Init(void) {//配置RCC时钟&#xff1a;RCC_APB2Perip…

前端架构: 脚手架之包管理工具的案例对比及workspaces特性的使用与发布过程

npm的workspaces 特性 1 &#xff09;使用或不使用包管理工具的对比 vue-cli 这个脚手架使用 Lerna 管理&#xff0c;它的项目显得非常清晰在 vue-cli 中包含很多 package 点开进去&#xff0c;每一个包都有package.json它里面有很多项目&#xff0c;再没有 Lerna 之前去维护和…

【大数据】Flink SQL 语法篇(七):Lookup Join、Array Expansion、Table Function

《Flink SQL 语法篇》系列&#xff0c;共包含以下 10 篇文章&#xff1a; Flink SQL 语法篇&#xff08;一&#xff09;&#xff1a;CREATEFlink SQL 语法篇&#xff08;二&#xff09;&#xff1a;WITH、SELECT & WHERE、SELECT DISTINCTFlink SQL 语法篇&#xff08;三&…

SpringCloudNacos注册中心服务分级存储模型

文章目录 服务分级存储模型概述配置集群同集群优先的负载均衡 权重配置总结 之前对 Nacos注册中心入门 已经做了演示. 这篇文章对 Nacos 的服务分级存储模型做理论与实践. 服务分级存储模型概述 一个服务可以有多个实例&#xff0c;例如我们的 user-server&#xff0c;可以有:…

C#使用iText7给PDF文档添加书签

上一篇文章将SqlSugar官网文档中每个链接对应的网页生成独立PDF文档再合并为单个PDF文档&#xff0c;但是没有书签&#xff0c;八百多页的内容查找和跳转都不方便&#xff0c;本文学习和使用iText7给PDF文档添加多级书签。   添加多级书签分为两大步骤&#xff1a;1&#xff…

老卫带你学---leetcode刷题(202. 快乐数)

202. 快乐数 问题 「快乐数」 定义为&#xff1a; 对于一个正整数&#xff0c;每一次将该数替换为它每个位置上的数字的平方和。 然后重复这个过程直到这个数变为 1&#xff0c;也可能是 无限循环 但始终变不到 1。 如果这个过程 结果为 1&#xff0c;那么这个数就是快乐数。…

VR全景HDR拍摄教程

什么是HDR&#xff1f; HDR可以用在哪里&#xff1f; 书面解释&#xff1a;HDR&#xff08;高动态范围 High Dynamic Range&#xff09;摄影&#xff0c;是摄影领域广泛使用的一种技术。 是不是有点懵&#xff1f; 我们来看一个实际的拍摄现场环境&#xff0c;你就懂了 我们…

使用 Gradle 版本目录进行依赖管理 - Android

/ 前言 / 在软件开发中&#xff0c;依赖管理是一个至关重要的方面。合理的依赖版本控制有助于确保项目的稳定性、安全性和可维护性。 Gradle版本目录&#xff08;Version Catalogs&#xff09;是 Gradle 构建工具的一个强大功能&#xff0c;它为项目提供了一种集中管理依赖…

定时任务框架

定时任务的框架有哪些 ● Timer&#xff0c;JDK自带的&#xff0c;比较简单&#xff0c;使用的时候&#xff0c;定义一个TimerTask&#xff0c;实现run方法&#xff0c;然后定义一个Timer类&#xff0c;调用timer.schedule(timerTask,1000,3000); ○ 缺点&#xff1a;单线程、…

附加Numpy数组

参考&#xff1a;Append Numpy Array 引言 在数据科学和机器学习领域&#xff0c;处理大规模数据集是一项重要且常见的任务。为了高效地处理数据&#xff0c;numpy是一个非常强大的Python库。本文将详细介绍numpy中的一个重要操作&#xff0c;即如何附加&#xff08;append&a…

LeetCode:2867. 统计树中的合法路径数目(筛质数+ DFS Java)

目录 2867. 统计树中的合法路径数目 题目描述&#xff1a; 实现代码与思路&#xff1a; 筛质数 DFS 原理思路&#xff1a; 2867. 统计树中的合法路径数目 题目描述&#xff1a; 给你一棵 n 个节点的无向树&#xff0c;节点编号为 1 到 n 。给你一个整数 n 和一个长度为 …

西软云XMS operate XXE漏洞

免责声明&#xff1a;文章来源互联网收集整理&#xff0c;请勿利用文章内的相关技术从事非法测试&#xff0c;由于传播、利用此文所提供的信息或者工具而造成的任何直接或者间接的后果及损失&#xff0c;均由使用者本人负责&#xff0c;所产生的一切不良后果与文章作者无关。该…

linux使用scp命令来在两台Linux设备之间传输文件

1、linux怎么将一个文件发送到另一个linux设备特定目录下 可以使用scp命令&#xff08;secure copy&#xff09;来将文件从一个Linux设备复制到另一个Linux设备的特定目录下。假设你要将本地文件localfile.txt发送到远程设备的/remote/directory目录下&#xff0c;你可以使用以…

Oracle修改用户密码之后连接特别慢的问题

一、问题现象 oracle数据库密码修改后连接速度特别慢&#xff0c;甚至出现超时的问题&#xff0c;查询表也特别慢 更改密码后&#xff0c;每次连接异常慢&#xff0c;就算用正确的密码连接&#xff0c;验证延时也非常大&#xff0c;导致应用程序连接反复出现超时现象&#xf…

Jquery操作DOM对象

文章目录 目录 文章目录 本章目标 一.DOM操作分类 二.JQuery中的DOM操作 内容操作 属性值操作 节点操作 节点属性操作 节点遍历 总结 本章目标 使用Jquery操作网页元素使用JQuery操作文本与属性值内容使用JQuery操作DOM节点使用Jquery遍历DOM节点使用JQuery操作CSS-DOM 一…

Groovy(第八节) Groovy 之类

目录 Song 类 Groovy 类就是 Java 类 类的关系 类初始化 核心的灵活性

WebServer -- 日志系统(下)

目录 &#x1f33c;整体思路 &#x1f382;基础API fputs 可变参数宏 __VA_ARGS__ fflush &#x1f6a9;流程图与日志类定义 流程图 日志类定义 &#x1f33c;功能实现 生成日志文件 && 判断写入方式 日志分级与分文件 &#x1f33c;整体思路 日志系统分两部…

常见概率分布介绍

介绍 概率分布是统计学中用于描述随机变量的概率特征的函数。以下是几种常用的概率分布&#xff1a; 均匀分布&#xff08;Uniform Distribution&#xff09;: 离散均匀分布: 每个结果发生的概率相等。连续均匀分布: 任意两个相同长度的区间内取值的概率相同。 二项分布&am…

无法调试MFC源码

VS无法调试MFC源码 起初 有时候就是这么无奈&#xff0c;MFC源码各种问题没有办法调试&#xff0c;可是又想看下代码如何调用&#xff0c;里面做了些什么&#xff0c;从哪儿调出&#xff0c;学习一下大神的思路什么的。整理一下有可能的原因。 检查生成代码设置 需要设置正…