Spring Boot项目中怎么构建多模块的应用

在大型项目开发中,将项目分解为多个模块不仅可以增强代码的可维护性,还能提高开发效率。Spring Boot 提供了对多模块项目的良好支持,使得我们可以轻松地构建复杂的企业级应用程序。在这篇文章中,我们将深入探讨如何在Spring Boot项目中构建多模块的应用,包括多模块的原理、项目结构以及代码示例。

为了有效管理多个模块间的依赖版本,通常推荐使用BOM(Bill of Materials)。本文将详细介绍如何在Spring Boot项目中构建多模块应用,并使用子模块BOM来集中管理依赖版本。

一、为什么要使用多模块结构?

在一个多模块项目中,通常有一个主模块(也称为父模块),它包含多个子模块和一个bom模块。父模块负责管理子模块和插件配置。每个子模块都可以独立开发和测试,并且能够与其他模块协同工作。bom模块用来统一管理项目依赖版本。

多模块项目的核心优势包括:

  • 分而治之:将大项目拆分为多个模块,减少模块之间的耦合,提高可维护性。
  • 独立开发:各模块可以独立开发和测试,便于团队协作。
  • 重用性:模块可以在其他项目中复用,提高开发效率。

二、项目结构

一个典型的多模块项目结构如下:

my-spring-boot-app/
|-- pom.xml                 # 父项目pom文件
|-- bom/                    # BOM模块
|   |-- pom.xml             # BOM模块pom文件
|-- common/                 # 公共模块
|   |-- cache/                  # 缓存组件
|       |-- pom.xml             # 缓存组件pom文件
|       `-- src/main/java/      # 缓存组件Java源码
|   |-- pom.xml             # 公共模块pom文件
|-- business/               # 业务模块
|   |-- order/                  # 订单模块
|       |-- pom.xml             # 订单模块pom文件
|       `-- src/main/java/      # 订单模块java源码
|   |-- trade/                   # 交易模块
|       |-- pom.xml             # 交易模块pom文件
|       `-- src/main/java/      # 交易模块Java源码  
|   |-- pom.xml             # 业务模块pom文件
  • my-spring-boot-app/: 主模块,用于管理子模块。
  • common/, business/: 子模块,以及子模块下的子模块各自独立进行开发和维护。
  • bom/: bom模块,用于统一管理项目的依赖包和插件版本。

三、构建多模块项目

1. 创建主模块

首先,创建一个Maven项目作为主模块。在主模块的pom.xml中,我们需要声明该项目是一个父模块,并列出所有的子模块。

<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>com.nft</groupId><artifactId>nft-bom</artifactId><version>${revision}</version><relativePath>./nft-bom/pom.xml</relativePath></parent><artifactId>nft</artifactId><packaging>pom</packaging><description>NFT System</description><properties><revision>1.0.0-SNAPSHOT</revision></properties><modules><module>nft-bom</module><module>nft-business</module><module>nft-common</module></modules></project>
 2. 创建子模块

接下来,创建子模块。在每个子模块中,pom.xml文件需要继承主模块的配置:

2.1.创建子模块common及其子模块
  • 创建common模块
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>com.nft</groupId><artifactId>nft</artifactId><version>${revision}</version></parent><groupId>com.nft.common</groupId><artifactId>nft-common</artifactId><packaging>pom</packaging><description>Nft Common Modules</description><modules><module>nft-cache</module></modules></project>
  • 创建comon的子模块cache
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>com.nft.common</groupId><artifactId>nft-common</artifactId><version>${revision}</version></parent><artifactId>nft-cache</artifactId><description>nft cache module</description><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-cache</artifactId></dependency><dependency><groupId>org.hibernate.orm</groupId><artifactId>hibernate-jcache</artifactId></dependency><dependency><groupId>org.redisson</groupId><artifactId>redisson</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId></dependency><dependency><groupId>tech.jhipster</groupId><artifactId>jhipster-framework</artifactId></dependency><dependency><groupId>org.apache.commons</groupId><artifactId>commons-lang3</artifactId></dependency></dependencies>
</project>
2.2.创建子模块business及其子模块
  • 创建business模块
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>com.nft</groupId><artifactId>nft</artifactId><version>${revision}</version></parent><groupId>com.nft.business</groupId><artifactId>nft-business</artifactId><packaging>pom</packaging><description>Nft Business Modules</description><modules><module>nft-order</module><module>nft-trade</module></modules></project>
  • 创建business的子模块order
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>com.nft.business</groupId><artifactId>nft-business</artifactId><version>${revision}</version></parent><artifactId>nft-order</artifactId><description>Nft Order Modules</description><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-undertow</artifactId></dependency><dependency><groupId>com.nft.common</groupId><artifactId>nft-cache</artifactId></dependency></dependencies><build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins></build>
</project>
  • 创建business的子模块trade
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>com.nft.business</groupId><artifactId>nft-business</artifactId><version>${revision}</version></parent><artifactId>nft-trade</artifactId><description>Nft Trade Modules</description><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-undertow</artifactId></dependency></dependencies>
</project>
3. 配置子模块之间的依赖 

如果模块之间有依赖关系,例如nft-order依赖于nft-cache,可以在nft-orderpom.xml中添加依赖:

<!--版本在bom中配置-->
<dependency><groupId>com.nft.common</groupId><artifactId>nft-cache</artifactId>
</dependency>
4.在子模块中创建BOM来管理依赖和插件版本

接下来,我们在 my-spring-boot-app 项目中创建 bom 子模块,用来管理所有子模块的依赖和插件版本。

创建 bom 模块的 pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>3.3.3</version><relativePath/><!-- lookup parent from repository --></parent><groupId>com.nft</groupId><artifactId>nft-bom</artifactId><version>${revision}</version><packaging>pom</packaging><description>Bill of materials for nft modules</description><properties><nft.version>1.0.0-SNAPSHOT</nft.version><java.version>21</java.version><spring-boot.version>3.3.3</spring-boot.version><jhipster-framework.version>8.7.0</jhipster-framework.version><redisson.version>3.35.0</redisson.version><!-- plugin versions --><flatten-maven-plugin.version>1.6.0</flatten-maven-plugin.version></properties><dependencyManagement><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId><version>${spring-boot.version}</version><exclusions><exclusion><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-tomcat</artifactId></exclusion></exclusions></dependency><dependency><groupId>org.redisson</groupId><artifactId>redisson</artifactId><version>${redisson.version}</version></dependency><dependency><groupId>tech.jhipster</groupId><artifactId>jhipster-framework</artifactId><version>${jhipster-framework.version}</version></dependency><dependency><groupId>com.nft.common</groupId><artifactId>nft-cache</artifactId><version>${revision}</version></dependency><!-- fix vulnerable --><dependency><groupId>io.undertow</groupId><artifactId>undertow-core</artifactId><version>2.3.17.Final</version></dependency></dependencies></dependencyManagement><build><pluginManagement><plugins><plugin><groupId>org.codehaus.mojo</groupId><artifactId>flatten-maven-plugin</artifactId><version>${flatten-maven-plugin.version}</version></plugin></plugins></pluginManagement><plugins><plugin><groupId>org.codehaus.mojo</groupId><artifactId>flatten-maven-plugin</artifactId><configuration><updatePomFile>true</updatePomFile><flattenMode>oss</flattenMode></configuration><executions><execution><id>flatten</id><phase>process-resources</phase><goals><goal>flatten</goal></goals></execution><execution><id>flatten.clean</id><phase>clean</phase><goals><goal>clean</goal></goals></execution></executions></plugin></plugins></build></project>
 5. 编写代码

在各自的src/main/java目录下,编写模块对应的代码。例如在nft-order中编写一个简单的Spring Boot应用:

package com.spring.nft.order;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;@SpringBootApplication
public class OrderServiceApplication {public static void main(String[] args) {SpringApplication.run(OrderServiceApplication.class, args);}}

其他模块可以编写类似的代码。子模块中的类可以互相调用,从而实现模块之间的协作。

6. 构建和运行项目 

在主模块的根目录下,运行以下命令构建整个项目:

mvn clean install

构建完成后,可以运行各个子模块的Spring Boot应用:

mvn spring-boot:run -pl nft-order

四、使用BOM管理的好处

通过在 bom 子模块中集中管理依赖和插件版本,父模块和子模块的 pom.xml 将变得更加简洁和可维护。

  • 统一依赖版本:通过BOM模块集中管理依赖和插件版本,避免了多个子模块中手动管理版本的一致性问题。
  • 减少冗余配置:子模块只需声明依赖,而不需要关注具体的版本号,所有版本管理集中在一个地方。

五、总结

通过本文的介绍,我们了解了如何在Spring Boot项目中构建多模块应用,并且通过实际的示例展示了如何配置和使用多模块结构。在实际开发中,根据项目的需求,合理设计模块结构,不仅可以提高开发效率,还能有效地管理项目的复杂性。

使用子模块BOM来管理多模块项目的依赖和插件版本,是一种高效且可维护的方案。通过这种方式,可以将所有版本信息集中在一个地方,使得整个项目的依赖和插件管理变得更加简洁和一致。在复杂项目中,这种方法能够有效地减少版本冲突和管理成本。

希望本文能帮助你在实际项目中更加灵活和有效地使用Spring Boot多模块结构。如果你有任何问题或建议,欢迎在评论区留言讨论。

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

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

相关文章

【Rust练习】12.枚举

练习题来自&#xff1a;https://practice-zh.course.rs/compound-types/enum.html 1 // 修复错误 enum Number {Zero,One,Two, }enum Number1 {Zero 0,One,Two, }// C语言风格的枚举定义 enum Number2 {Zero 0.0,One 1.0,Two 2.0, }fn main() {// 通过 as 可以将枚举值强转…

使用FFmpeg的AVFilter转换YUV到RGB

AVFilter 是 FFmpeg 库 libavfilter 的核心组件&#xff0c;提供了一套强大的音视频处理框架&#xff0c;用于对音视频流进行复杂的过滤、转换和效果处理。通过 AVFilter&#xff0c;开发者可以构建自定义的滤镜图&#xff08;filter graph&#xff09;&#xff0c;实现各种音视…

(每日一问)操作系统:常见的 Linux 指令详解

&#xff08;每日一问&#xff09;操作系统&#xff1a;常见的 Linux 指令详解 Linux 系统作为一种开源的操作系统&#xff0c;以其高效、稳定和安全的特性&#xff0c;广泛应用于服务器、开发环境和嵌入式系统等领域。日常使用 Linux&#xff0c;掌握常见的基本指令至关重要&a…

Transformer预测 | 基于Transformer心率时间序列预测(tensorflow)

效果一览 基本介绍 Transformer预测 | 基于Transformer心率时间序列预测(tensorflow) 程序设计 import pandas as pd from pandas.plotting import lag_plot from statsmodels.graphics

EP1 banner海报swiper轮播器

文件路径&#xff1a; E:/homework/uniappv3tswallpaper/pages/index/index.vue <template><view class"homeLayout"><view class"banner"><swiper :indicator-dots"true" :autoplay"true" :interval"3000…

变量数据类型 Day3

1. 变量 1.1 变量的概念 变量是计算机内存中的一块存储单元&#xff0c;是存储数据的基本单元变量的组成包括&#xff1a;数据类型、变量名、值&#xff0c;后文会具体描述变量的本质作用就是去记录数据的&#xff0c;比如说记录一个人的身高、体重、年龄&#xff0c;就需要去…

script中的src

<script src"http://www.somewhere.com/afile.js"></script> 浏览器在解析这个资源时&#xff0c;会向 src 属性指定的路径发送一个 GET 请求&#xff0c;以取得相应资源&#xff0c;假定 是一个 JavaScript 文件。这个初始的请求不受浏览器同源策略限…

Verilog基础,原码,反码与补码的概念

Verilog模块初认识 1、Verilog模块(Module) Verilog中的module可以看成一个具有输入输出端口的黑盒子&#xff0c;该黑盒子有输入和输出接口(信号)&#xff0c;通过把输入在盒子中执行某些操作来实现某项功能。(类似于C语言中的函数) 图1 模块示意图 1.1 模块描述 图1 所示的…

2024年【防爆电气】试题及解析及防爆电气模拟考试题库

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 防爆电气试题及解析考前必练&#xff01;安全生产模拟考试一点通每个月更新防爆电气模拟考试题库题目及答案&#xff01;多做几遍&#xff0c;其实通过防爆电气复审模拟考试很简单。 1、【单选题】()利用输送爆炸危险…

Einsum(Einstein summation convention)

Einsum&#xff08;Einstein summation convention&#xff09; 笔记来源&#xff1a; Permute和Reshape嫌麻烦&#xff1f;einsum来帮忙&#xff01; The Einstein summation convention is a notational shorthand used in tensor calculus, particularly in the fields of …

大美祖国之地名篇-探寻全国同名地名

目录 前言 一、地名数据库 1、数据库模型 2、数据表结构 二、实践之旅&#xff0c;发现同名地名 1、省、市同名 2、市、县同名 3、 区县、乡镇同名 4、乡镇和村委会同名 三、总结 前言 我们祖国地大物博&#xff0c;从北到南&#xff0c;从东到西。祖国位于亚洲东部&…

九,自定义转换器详细操作(附+详细源码解析)

九&#xff0c;自定义转换器详细操作&#xff08;附详细源码解析&#xff09; 文章目录 九&#xff0c;自定义转换器详细操作&#xff08;附详细源码解析&#xff09;1. 基本介绍2. 准备工作3. 自定义转换器操作4. 自定义转换器的注意事项和细节5. 总结&#xff1a;6. 最后&…

电脑怎么限制软件上网?推荐三个超详细的小妙招(软件上网权限管理)

想要控制电脑上哪些软件可以上网、哪些不能&#xff1f;不管是为了保护隐私、节省流量&#xff0c;还是提高工作效率&#xff0c;限制软件上网都是非常实用的小妙招&#xff01; 今天给大家带来三个超详细的招数&#xff0c;帮助你轻松管理软件的上网权限。让那些不该上网的应…

最长的指定瑕疵度的元音子串

题 目描述 开头和结尾都是元音字母(aeiouAEIOU)的字符串为元音字符串&#xff0c;其中混杂的非元音字母数量为其瑕疵度。比如. 1.“a”、“aa"是元音字符串&#xff0c;其瑕疵度都为02.“aiur"不是元音字符串(结尾不是元音字符)3.“abira”是元音字符串&#xff0c…

RocketMQ 集群与高可用性:深入解析与实践指南

目录 前言 RocketMQ集群与高可用性 一、主从同步机制 1.1 使用场景 1.2 原理机制 1.3 数据同步流程 1.4 优缺点 二、RocketMQ 故障转移机制&#xff08;Failover&#xff09; 2.1 使用场景 2.2 原理机制 2.3 故障转移的注意事项 2.4 优缺点 三、主从架构和故障转移…

MySQL的 where 1=1会不会影响性能

MySQL的 where 11会不会影响性能&#xff1f; 一、引言 在编写SQL语句时&#xff0c;我们经常会遇到需要动态拼接查询条件的情况&#xff0c;尤其是在使用MyBatis这类ORM框架时。为了简化代码&#xff0c;很多开发者会使用where 11来开始他们的查询语句&#xff0c;然后通过程…

VSCode学习笔记

1. 快捷键 KeyDescriptionPlatformF1打开命令面板&#xff08;Command Palette&#xff09;Win10Shift Delete剪切当前光标所在的代码行Win10 2. 文件 2.1 在文件列表中定位当前文件 操作路径&#xff1a;右键单击文件名 ⇒ 在右键菜单中点击 【Reveal in Explorer View】

云计算第四阶段----CLOUD 01-03

CLOUD Day01 一、虚拟化平台搭建 虚拟化技术产品介绍 #黄线标注的&#xff0c;都是比较主流且常用的虚拟化平台。 虚拟化与云计算的关系 虚拟化是一种技术&#xff0c;它允许在单个物理服务器上创建和运行多个虚拟机&#xff08;VMs&#xff09;&#xff0c;每个虚拟机都有其…

python编程知识(实现数据加密和解密)

&#x1f468;‍&#x1f4bb;个人主页&#xff1a;开发者-曼亿点 &#x1f468;‍&#x1f4bb; hallo 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! &#x1f468;‍&#x1f4bb; 本文由 曼亿点 原创 &#x1f468;‍&#x1f4bb; 收录于专栏&#xff1a…

JavaScript使用高德API显示地图

前言 在JavaScript中&#xff0c;使用Leaflet库显示地图是一种常见的做法。Leaflet是一个开源的JavaScript库&#xff0c;用于在Web应用程序中创建互动地图。它非常轻量级&#xff0c;易于使用&#xff0c;并且提供了多种功能&#xff0c;使开发者能够轻松地将地图集成到他们的…