阅读 259

maven中有重复依赖该怎么搞(maven自动去掉重复依赖)

在开发过程中,可能不可避免地都遇到过依赖版本重复,导致运行出现问题的情况,如果你遇到过,建议你看看,如果你还没遇到过,更建议你看看。

在我们项目结构比较小的时候,可能只有一两个pom文件,通过肉眼就能看到有没有重复依赖项,但是当我们的项目开发越来越庞大,除了自己引入的依赖,还有一些通过第三方库间接引入的依赖,一旦出现依赖冲突,并且版本不一致时,很有可能会导致我们的项目在运行时出现问题。

本期内容,主要包括以下内容:

  • 如何快速检查pom中的重复依赖项

  • 如何在构建时有重复依赖强制失败

为什么要检测重复依赖关系

如果在pom中有重复依赖,有一个主要的风险点,就是在我们构建时,可能高版本的依赖不会构建在我们项目中。

例如有以下pom.xml:

<project>     <dependencies>         <dependency>             <groupId>org.apache.commons</groupId>             <artifactId>commons-lang3</artifactId>             <version>3.12.0</version>         </dependency>         <dependency>             <groupId>org.apache.commons</groupId>             <artifactId>commons-lang3</artifactId>             <version>3.11</version>         </dependency>     </dependencies> </project> 复制代码

引入了commons-lang3的两个依赖项,并且版本不同。接下来,让我们看看如何使用Maven命令来检测这些重复依赖项。

dependency:tree命令

通过终端运行命令mvn dependency:tree并查看输出。

从日志中我们可以看到,有warning日志提示存在重复依赖项(标注1处);并且最后构建到项目中的是3.11版本(标注2处),是因为maven在选择依赖项时会选择最后一个。

dependency:analyze-duplicate 命令

接下来我们通过命令dependency:analyze-duplicate来检查重复依赖项:

从结果看,同样会在WARNING日志中打印重复依赖项,并且在INFO日志中会列出重复依赖的jar。

有重复依赖强制构建失败

在上文中,我们了解到如何检测重复依赖项,但构建仍然会成功,这可能会导致使用的jar包版本不正确。

我们可以使用maven enforcer插件,如果存在重复的依赖项,可以确保构建不成功。

需要先将maven enforcer插件添加到pom.xml中,并添加一个规则banDuplicatePomDependencyVersions:

<build>     <plugins>         <plugin>             <groupId>org.apache.maven.plugins</groupId>             <artifactId>maven-enforcer-plugin</artifactId>             <version>3.0.0</version>             <executions>                 <execution>                     <id>no-duplicate-declared-dependencies</id>                     <goals>                         <goal>enforce</goal>                     </goals>                     <configuration>                         <rules>                             <banDuplicatePomDependencyVersions/>                         </rules>                     </configuration>                 </execution>             </executions>         </plugin>     </plugins> </build> 复制代码

接下来我们进行验证:

可以看到构建失败。

一旦我们确定了重复的依赖项,我们就可以在pom.xml文件中删除,保留我们需要的依赖。

小结

在本期内容中,主要讲述如何使用mvn dependency:tree和mvn dependency:analyze-duplicate命令检测maven中的重复依赖项。

我们还了解了如何使用maven enforcer插件通过内置规则来使包含重复依赖项的应用构建失败。

我是小黑,一名在互联网“苟且”的程序员

流水不争先,贵在滔滔不绝


作者:小黑说Java
链接:https://juejin.cn/post/7046946791710785544


文章分类
代码人生
文章标签
版权声明:本站是系统测试站点,无实际运营。本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 XXXXXXo@163.com 举报,一经查实,本站将立刻删除。
相关推荐