在我们项目结构比较小的时候,可能只有一两个pom文件,通过肉眼就能看到有没有重复依赖项,但是当我们的项目开发越来越庞大,除了自己引入的依赖,还有一些通过第三方库间接引入的依赖,一旦出现依赖冲突,并且版本不一致时,很有可能会导致我们的项目在运行时出现问题。
本期内容,主要包括以下内容:
- 如何快速检查pom中的重复依赖项
- 如何在构建时有重复依赖强制失败
如果在pom中有重复依赖,有一个主要的风险点,就是在我们构建时,可能高版本的依赖不会构建在我们项目中。
例如有以下pom.xml:
复制代码 org.apache.commons commons-lang33.12.0 org.apache.commons commons-lang33.11
引入了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:
复制代码 org.apache.maven.plugins maven-enforcer-plugin3.0.0 no-duplicate-declared-dependencies enforce
接下来我们进行验证:
可以看到构建失败。
一旦我们确定了重复的依赖项,我们就可以在pom.xml文件中删除,保留我们需要的依赖。
小结在本期内容中,主要讲述如何使用mvn dependency:tree和mvn dependency:analyze-duplicate命令检测maven中的重复依赖项。
我们还了解了如何使用maven enforcer插件通过内置规则来使包含重复依赖项的应用构建失败。



