Maven 处理依赖冲突

Maven处理依赖冲突

什么是依赖冲突?

当项目中直接或者间接的引入多个版本的同一依赖时则会出现依赖冲突

如何解决?

Maven自动处理依赖冲突的规则

路径优先原则

当依赖冲突发生时,Maven 会优先选择路径最短的依赖版本。路径长度是指从当前项目到依赖的层级深度。例如:项目直接引入的a:v1,及b:v1,但b:v1中引入了a:v2。那么项目自动会引入a:v1。因为a:v1b:v1->a:v2 路径更短
实例:package-b 引入了 logback.1.5.14,及package-a 但是,package->a 引入了 logback.1.5.13。直接maven 选择了logback.1.5.14 符合路径优先原则

第一声明优先原则

如果两个依赖的路径长度相同,Maven 会优先选择在 pom.xml 文件中先声明的依赖版本。例如:项目直接引入了a:v1->b:v1,与a:v2->b:v2 但是a:v1是在a:v2前先声明的,那么就会选择a:v2中的b:v1 反之选择b:v2

注意

坑!!!!

直接在pom.xml中引入两个相同坐标但不同版本的依赖时,不会按照声明优先原则选择。而是使用最后声明的依赖。

[WARNING] 'dependencies.dependency.(groupId:artifactId:type:classifier)' must be unique: ch.qos.logback:logback-core:jar -> version 1.5.14 vs 1.5.13 @ line 23, column 21->表示同一个pom下不能声明相同的坐标。这就导致maven直接选择了最后声明的依赖

子模块覆盖父模块

子模块可以通过在自己的 pom.xml 文件中直接声明依赖的版本来覆盖父模块的版本。Maven 的依赖解析规则会优先考虑子模块中直接声明的依赖版本。

父模块声明dependency子模块覆盖dependency
父模块声明dependencyManagement 子模块覆盖dependency
父模块声明dependencyManagement 子模块覆盖dependencyManagement

Maven手动处理依赖冲突

Maven自动处理依赖后导致引入了低版本的依赖

package-g:1.0,package-g:2.0。通常我们是使用高版本的包,但是因为路径优先原则,导致使用了低版本的依赖。这种就需要手动解决了。

解决方案

思路:通常我们高版本的依赖兼容低版本的依赖。那么我只需要依赖高版本的依赖即可。

exclusions

使用于不能修改package-h内部的场景

xml 复制代码
<dependencies>
      <dependency>
          <groupId>com.mfyuan</groupId>
          <artifactId>package-j</artifactId>
          <version>1.0-SNAPSHOT</version>
      </dependency>
      <dependency>
          <groupId>com.mfyuan</groupId>
          <artifactId>package-h</artifactId>
          <version>1.0-SNAPSHOT</version>
          <exclusions>
              <exclusion>
                  <groupId>com.mfyuan</groupId>
                  <artifactId>package-g</artifactId>
              </exclusion>
          </exclusions>
      </dependency>
  </dependencies>

将低版本的依赖通过exclusion给排除掉即可。这样就没有发生依赖冲突了。

optional

optionaltrue时,不将该依赖传递给外层。这样就可以避免造成依赖冲突的问题。

适用场景:可以修改package-h内部的pom.xml一般都为自己开发的jar包

xml 复制代码
<dependencies>
    <dependency>
        <groupId>com.mfyuan</groupId>
        <artifactId>pacage-g</artifactId>
        <version>1.0-SNAPSHOT</version>
        <!--不将该依赖传递给外层-->
        <optional>true</optional>
    </dependency>
</dependencies>
注意

高版本如果没有兼容低版本怎么办?这种情况会造成编译失败,或者ClassNotFoundException如果你又需要高版本的功能也需要低版本的功能那么这种问题是解决不了的。

工具

idea插件:Maven Helper

可以快速查看那些依赖存在冲突

相关推荐
cooldream200921 分钟前
有状态服务、无状态服务与Session机制详解
java·开发语言·系统架构师
weixin_4365250728 分钟前
芋道框架 账号未登录、租户标识未传递
java·linux·服务器
小文数模28 分钟前
2025数维杯数学建模C题完整分析参考论文(共36页)(含模型、可运行代码、数据)
python·数学建模·matlab
是梦终空29 分钟前
Python毕业设计219—基于python+Django+vue的房屋租赁系统(源代码+数据库+万字论文)
python·django·vue·毕业设计·毕业论文·源代码·房屋租赁系统
magic 24531 分钟前
第2章——springboot核心机制
java·spring boot·spring
YKPG32 分钟前
C++学习-入门到精通-【5】类模板array和vector、异常捕获
java·c++·学习
Q_Q196328847533 分钟前
python小区物业管理系统-小区物业报修系统
开发语言·spring boot·python·django·flask·node.js·php
一只蒟蒻ovo37 分钟前
操作系统导论——第27章 插叙:线程API
java·开发语言
斯普润布特39 分钟前
Java-很深我只知其一构造(Builder)
java·开发语言
小小毛桃1 小时前
使用PyTorch训练马里奥强化学习代理的完整指南
人工智能·pytorch·python