0. 前言
相比起 Maven 的 XML 配置方式,Gradle 提供了一套简明的 DSL 用于构建Java 项目,使我们就像编写程序一样编写项目构建脚本。
本文将从无到有创建一个用 Gradle 构建的多模块 Spring Boot 项目,JDK 版本为8,IDEA 版本为 2022.3.1 。
1. 创建项目
打开IDEA,选择菜单:File -> New -> Project,在其中找到 Spring Initializr,创建一个全新的 demo 项目,创建成功后结构如下:

之后,程序会自动下载 Gradle 安装包,并且通过 Gradle 下载和引入的 jar 包。由于默认使用的镜像速度较慢,我们可以先取消下载,等后面配置好国内镜像后再重新下载,当然也可以慢慢等。
2. Gradle说明
在这里就不介绍Gradle 的优缺点了,只说一下本项目涉及的部分:
- build.gradle :管理依赖包的配置文件(相当于Maven的pom.xml)。
- gradlew :Gradle 命令的包装,当机器上没有安装 Gradle 时,可以直接用 gradlew 命令来构建项目。
- settings.gradle :可以视为多模块项目的总目录, Gradle 通过它来构建各个模块,并组织模块间的关系。
- gradle/wrapper包 :Gradle 的一层包装,能够让机器在不安装 Gradle 的情况下运行程序,便于在团队开发过程中统一 Gradle 构建的版本, 推荐使用 。
- gradle.properties :需手动创建,配置gradle环境变量,或配置自定义变量供 build.gradle 使用。
3. Gradle最佳实践
接下来,讲一下我个人使用 Gradle 的一些经验。
- 修改 gradle-wrapper.properties 中的 Gradle 下载镜像改为国内镜像。

- 新建 gradle.properties 文件,配置 Gradle 参数,提升构建速度。

- 将 maven 仓库地址改为国内地址
- 将经常变更的依赖包版本、 maven 库地址等变量提取到 gradle.properties 里, build.gradle 可直接读取使用。

- 使用 buildscript 方式引用 gradle plugins ,优点是可以使用自定义仓库,且便于子模块继承。

- 新建 spring.gradle 配置文件,引用相关的 Spring 依赖包。

- 在 build.gradle 里添加引用本地jar包的语句,这样配置后,仓库中没有的jar包,放到 src/libs 文件夹下就可以直接使用了,非常方便。


- 在 build.gradle 中添加一个拷贝 jar 包的 task ,在 build 或 bootJar 后执行,用于将子模块打包后,拷贝到根目录下。

4. 项目模块划分
4.1. 拆分思路
新项目默认是一个单模块的 SpringBoot 工程,而我们要将其改造为一个多模块项目,思路是,将项目拆分为多个子模块,分为三类: 服务、模块、组件 :
- 项目 :最顶级,与服务是一对多的关系,本项目为根目录;
- 服务 :对应一个可启动的 SpringBoot 工程,一般只有一个启动类,建议根据服务器资源和团队规模划分,与模块是一对多的关系,位置在 services 包下;
- 模块 :对应一个完整的业务,模块间边界清晰,将不同的业务解耦,便于扩展和维护,位置在 modules 包下;
- 组件 :将公用的代码部分提取为一个个组件,供不同的模块调用,与模块是多对多的关系,位置在 components 包下。
4.2. 拆分实践
- 服务 :创建一个示例服务:demo-boot
- 模块 :只是个框架,没有承载业务,象征性的建一个系统管理模块:demo-system ,任何系统都能用到;
- 组件 :建一个放工具类的组件:demo-common ,所有模块都会用到。
4.3. 具体配置
- 声明子模块 :在根目录下的 settings.gradle 里声明各个模块:

- 服务公共依赖 :在 services/build.gradle 里引用一些所有服务公用的一些依赖包,这里使用了 subprojects,表示应用于所有 services 包下的子模块,我们通过 sourceSet 的方式将根目录 src 下的文件,作为公共代码集成到每个服务中。

- 服务包含模块 :在 services/demo-boot/build.gradle 里引用模块 demo-system

- 模块公共依赖 :在 modules/build.gradle 里引用一些所有模块公用的一些依赖包,这里我们引用本地 src/libs 文件夹下的本地jar包。

- 模块包含组件 :在 modules/demo-system/build.gradle 里引用组件 demo-common

4.4. 代码结构
每次修改 Gradle 配置后,需要刷新生效(可改为自动)

-
模块
+关注
关注
7文章
2822浏览量
52809 -
JAVA
+关注
关注
20文章
2997浏览量
115694 -
程序
+关注
关注
117文章
3836浏览量
84767 -
spring
+关注
关注
0文章
341浏览量
15782 -
gradle
+关注
关注
0文章
26浏览量
995
发布评论请先 登录
Spring Boot如何实现异步任务
Spring Boot Starter需要些什么
启动Spring Boot项目应用的三种方法
Spring Boot从零入门1 详述
Spring Boot特有的实践
强大的Spring Boot 3.0要来了
怎样使用Kiuwan保护Spring Boot应用程序呢?
Spring Boot Web相关的基础知识
Spring Boot Actuator快速入门
Spring Boot启动 Eureka流程
Spring Boot的启动原理

Gradle构建的多模块Spring Boot项目
评论