避免版本冲突:Spring Boot项目中正确使用Maven的DependencyManagement

最近在做一个SpringBoot项目jar包升级的时候,忽略了Maven中dependencyManagement和dependencies元素的区别,导致线上出现了问题。今天,我们就来聊聊这两者的区别。

  1. dependencyManagement元素的应用场景

当我们在开发一个大型的后端项目时,模块通常很多,我们会使用Maven或者Gradle来管理项目,我们项目使用的是Maven。

项目中的每个模块通常都会依赖很多jar包,当jar包越来越多时,通常会把每个模块用到的公共的jar包提取出来,构建父POM文件。在父POM中,我们会使用dependencyManagement元素来管理包的版本。如此一来,子项目或者模块直接在直接引用jar包的依赖,不需要在指定版本号,下面是一个典型的父POM(pom.xml)。

XML 复制代码
<dependencyManagement>
        <dependency>
             <groupId>com.alibaba.fastjson2</groupId>
             <artifactId>fastjson2</artifactId>
             <version>2.0.39</version>
        </dependency>
        <dependency>
             <groupId>com.alibaba</groupId>
             <artifactId>transmittable-thread-local</artifactId>
             <version>2.12.1</version>
        </dependency>
</dependencyManagement>

假设我们有一个模块来引用父POM,配置如下所示:

XML 复制代码
    <!--继承父POM-->
    <parent>
        <groupId>com.lixiang.vehicle.framework</groupId>
        <artifactId>vehicle-framework-bom</artifactId>
        <version>1.0.0.0</version>
    </parent>

    <groupId>com.customer.api</groupId>
        <name>customer</name>
    <packaging>pom</packaging>

    <dependencies>
        <dependency>
            <groupId>com.alibaba.fastjson2</groupId>
            <artifactId>fastjson2</artifactId>
        </dependency>
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>transmittable-thread-local</artifactId>
        </dependency>
    </dependencies>

这样做的好处是:通过**父POM可以统一管理项目依赖所有公共jar包的版本,确保项目的各个模块依赖的jar包版本的一致。**如此一来,在服务的jar包版本升级时,只需要升级父POM管理的jar包版本,子项目或者子模块就会自动生效,而不需要按个升级每个子项目的jar版本。

  1. dependencies元素的特性

不管是父POM还是子项目或者子模块的POM,只要是在dependencies元素内部所定义的jar包,均会自动引入,并且这些依赖还会被子项目全部继承。

  1. dependencyManagement和dependencies区别

dependencyManagement用于集中管理依赖的版本,并不实际引入,而dependencies用于实际引入依赖

假如父POM和子项目的pom文件中都引入了一个共同的jar包,但是版本号不一样?那么子项目实际生效的版本是哪一个呢?答案是子项目引入的jar包版本。因此,子项目或者子模块想要使用父POM管理的jar包,直接引入即可,不需要指定版本号。

相关推荐
小屁孩大帅-杨一凡21 分钟前
python实现文件夹打包成jar
java·开发语言·python·pycharm·jar
RealmElysia41 分钟前
谷粒商城基础篇完结
java·微服务
lxl_h1 小时前
IDEA 打包普通JAVA项目为jar包
java·intellij-idea·jar
好奇的菜鸟1 小时前
解决 IntelliJ IDEA 启动错误:插件冲突处理
java·ide·intellij-idea
what_20181 小时前
idea添加作者注释和方法注释、属性注释
java·ide·intellij-idea
m0_748254091 小时前
2024.1.4版本的IntelliJ IDEA创建Spring Boot项目的详细步骤
java·spring boot·intellij-idea
m0_748239471 小时前
Spring IDEA 2024 安装Lombok插件
java·spring·intellij-idea
dr李四维1 小时前
PO、VO、DAO、BO、DTO、POJO 你能分清吗?
java·po·dao·dto·vo·pojo·bo
程序员大金1 小时前
基于SpringBoot+Vue的驾校管理系统
java·vue.js·spring boot·后端·mysql·spring·intellij-idea
m0_748239631 小时前
Java实战:Spring Boot application.yml配置文件详解
java·网络·spring boot