首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Maven 依赖树的解析规则

对于 Java 开发工程师来说,Maven依赖管理和代码构建的标准。遵循「约定大于配置」理念。Maven 是 Java 开发工程师日常使用的工具,本篇文章简要介绍一下 Maven依赖解析。...依赖树结构 在 pom.xml 的 dependencies 中声明依赖包后,Maven 将直接引入依赖,并通过解析直接依赖的 pom.xml 将传递性依赖导入到当前项目,最终形成一个树状的依赖结构。...针对这种多个版本构建依赖时,Maven 采用「短路径优先」原则,即 A 会依赖 2.0 版本的 E。如果想引入 1.0 版本的 E,需要直接在 A 的 pom 中声明 E 的版本。...依赖排除 我们可以使用 exclusion 来解决依赖冲突,但是 exclusion 会降低 Maven 依赖解析的效率,因为对应的 pom 文件不能缓存,每次都要重新遍历子树。...[2020-11-07-103350.png] Maven 命令行 mvn dependency:tree -Dverbose

2.9K40
您找到你想要的搜索结果了吗?
是的
没有找到

Maven 依赖调解源码解析(一):开篇

前言 相信久经沙场的 Java 开发同学们,一定对 Maven 这个工具不陌生。Maven依赖调解原则,便是经常聊到的话题。...的配套核心依赖 dependency:tree,包括两个项目: maven-dependency-plugin-2.8(源码下载:https://archive.apache.org/dist/...dependency:tree 是 Maven 的核心依赖插件,它在依赖解析时发挥重要作用,平时我们也经常使用命令 mvn dependency:tree 输出目录树进行查看。...这个插件由两部分组成,分别是 maven-dependency-plugin 和 maven-dependency-tree;前者包含了与「依赖」相关的多种插件,其中就包括 tree 插件;后者则是 tree...为了进行实验,我们需要搭建一个 Demo 项目,并用 Maven 管理依赖包。该项目名称为 mavenDependencyDemo,我们在其中创建五个模块 A、B、C、D、X。

47721

Maven构建和依赖管理解析

依赖管理在之前的传统 WEB 项目中,所依赖的 JAR 包都要复制到工程中,这就导致了工程比较大。...Maven 的解决方案:在 Maven 工程中,是不直接把 JAR 包直接导入到工程中的,其通过在 pom.xml 文件中添加所需的 JAR 包坐标来解决问题。...clean:主要处理项目构建后的清理工作site:主要处理项目的站点文档生成default 生命周期包含了右图的这些阶段compile 命令:下载所有当前项目所需要的插件,以及所有依赖的项目,然后进行构建...package 命令:从 pom 文件中获取打包类型,然后将打出来的 JAR 输出到对应目录install 命令:将打包完放在 target 目录下的 JAR 包部署到本地仓库POMpom.xm元素解析...project 这个元素是Maven的pom.xml文件的顶层元素。

13700

Maven 依赖

Maven 解析依赖信息时,首先会到本地仓库中查找依赖的 Jar 包 对于本地仓库中没有的依赖,就会去中央仓库查找,通过 Maven 坐标来获取 jar 包,获取到后会先下载到本地仓库 对于中央仓库中不存在的依赖包...,就会显示编译失败 ② 如果依赖的是自己或者团队开发的 Maven 工程,需要先使用 install 命令把被依赖maven 工程的 jar 包安装到本地仓库中 ③ 依赖范围,scope 配置就是依赖的范围...runtime:只在运行时使用,如 JDBC 驱动,适用于运行和测试阶段 4. test:只在测试时使用,用于编译和运行测试代码,不会随项目发布 5. system:类似 provided,需要显式提供包含依赖的...jar,Maven 不会在 Repository 中进行查找

90510

Maven 依赖调解源码解析(三):传递依赖,路径最近者优先

场景 A有这样的依赖关系:A->B->C->X(1.0)、A->D->X(2.0),X是A的传递性依赖,但是两条依赖路径上有两个版本的X,那么哪个X会被Maven解析使用呢?...两个版本都被解析显然是不对的,因为那会造成依赖重复,因此必须选择一个。根据路径最近者优先原则,该例中X(1.0)的路径长度为3,而X(2.0)的路径长度为2,因此X(2.0)会被解析使用。...也就是说,apache-maven-3.6.3 这个核心项目已经做出了「应该保留哪个依赖」的判断。 因此我们再次中断调试,回到 apache-maven-3.6.3 核心项目重新调试。...,让我们看看: 其实很容易发现,依赖解析过程就是一种深度遍历,这里的 recurse 方法会被不断递归。...小结 至此,我们已经知道了路径最近者优先原则的运行原理:依赖解析是一种深度遍历的过程,每当解析一个依赖后,均会将其放到 resolvedArtifacts 这个Map中,后续再看到同名的依赖时,进行冲突调解

52530

Maven 依赖调解源码解析(六):dependencyManagement 版本锁定

简单翻译一下,使用 dependencyManagement 声明的依赖若指定了版本,可以: 指定传递依赖的版本(即使传递依赖有自定义版本,也会被覆盖掉); 当直接依赖没有指定版本时,指定其版本...那回到 Maven 核心项目,看看 includeArtifact 方法被哪里调用了: 继续顺着调用链往上找, 看到很奇怪的现象,C 依赖的 X 变成 2.0 版本了,但是 C 中明明是 X(1.0...可以看到,解析 C 依赖的 X(1.0)时,被“manage”了,也即:版本被改成了 2.0。 很明显,版本号是以 managedVersions 为准的。...最终我们找到了这里: 至此,我们找到了「解析 dependencyManagement 中定义的依赖版本」的源码。...小结 依赖解析过程中,会解析 dependencyManagement 定义的依赖版本,如果解析到了,会以 dependencyManagement 重定义的依赖版本为准,也就是我们常提到的版本锁定。

72330

Maven 依赖管理

摘要 作为开发者,我们一直使用 Maven 来作为版本依赖管理工具,不过我们经常会遇到依赖冲突等问题,我们这边文章就来明确一下 Maven 是如何管理依赖与版本的。...: 修改是向后兼容的,一般表示引入了新功能 IncrementalVersion: 修改是向后兼容的,一般用于bug 修复 Maven依赖的选择策略 假设有一个项目P, 它有如下的依赖图: ?...那我们在构建的时候,哪些依赖会包含在构建中呢? 这就涉及到Maven依赖选择策略,Maven 有两条依赖选择规则: 1. 距离根节点最近的依赖会被选择使用 2....我们可以使用 exclude 方式将 Z 1.0 排除出依赖 总结 Maven依赖管理很灵活,但是当有很多的依赖时,很容易会造成依赖选择的不正确。...其实更真实的说法是,Maven 使用的这种依赖选择策略是有问题的,当遇到依赖冲突时,抛出异常由程序员决定选择哪个依赖是更好的选择,Maven 的这种选择依赖的方式运气好一点的在启动或测试时发现,运气不好等到上线甚至埋藏很久才会运行异常

67420

Maven 依赖调解源码解析(二):如何调试 Maven 源码和插件源码

因此我们需要以调试方式启动 Maven 源码,以便让流程继续走下去。 打开 apache-maven-3.6.3 项目,新建一个远程调试配置,端口选择 8000。如下图所示。...以调试方式启动 Maven 源码(你可以在入口处打个断点),就会发现流程走进来了。如下图所示。 然后我们就可以愉快地进行调试了。...注 1:本文以 Maven 核心源码为例介绍了调试流程,其实 Maven 插件的源码调试方法也是一模一样的。...注 2:这种调试的方法很灵活,我们可以随便选择不同的业务项目,与 Maven 源码进行联调。当然也有很多调试 Maven 源码的方法,但要设置一大堆东西。...搞清楚如何调试 Maven 和插件源码后,我们就可以开始正式分析了。

80931

Maven 依赖管理

Maven 坐标 3. 依赖冲突 3.1 冲突产生原因 3.2 解决冲突的办法 1....前言 在我们创建使用 Maven 项目的过程中,当需要用到第三方的控件时,都是通过依赖管理来达成,也就是 Maven 项目中必有的 pom.xml 文件。...依赖冲突 3.1 冲突产生原因 Maven 项目中,通常都会定义血多 dependency,每个 dependency 内部也会定义它的 dependency,而有时各个依赖之间会产生冲突,冲突的原因通常主要是...「由于 jar 包依赖的传递性」,如果在一个项目中同时引入了一个依赖的不同版本,就可能导致依赖冲突。...「移除依赖:用于排除某项依赖依赖包」 除开上述策略外,我们也可以手动在 pom.xml 中使用 标签来排除发生冲突的依赖包,如下面用于排除 sring-core 冲突的例子:

84520

Maven依赖机制

------------ 场景2: 路径1:A->B->C(version:1.0) 路径2:A->D->C(version:2.0) 路径1和路径2中C到A的距离是相同的,通过路径最近者优先原则无法判断该使用哪个依赖...,此时Maven会使用第一声明者优先原则进行选择,第一声明者优先原则是指在POM依赖中声明顺序最靠前的那个依赖会被选择。...依赖范围介绍 compile:编译依赖范围,默认使用该依赖范围,在所有classpath中都可用,并且依赖将传播到依赖项目。...import:导入依赖范围,该依赖范围不会对三种classpath产生影响,只有在部分中的pom类型依赖才支持此范围,它指示要替换为指定POM的部分中的有效依赖列表的依赖。...由于它们被替换,具有导入范围的依赖实际上不参与限制依赖的传递性。 依赖范围对依赖传递的影响 每个范围(import导入依赖范围除外)以不同方式影响传递依赖性,如下表所示。

1.4K30

快速学习Maven-Maven依赖

maven 工程中,这种现象我们称为依赖传递。...依赖冲突的解决 接着添加一个依赖 ? 我们会发现这两个 jar 包同时都依赖了 spring-beans ?...这就造成了依赖冲突。解决依赖冲突有以下原则: 依赖调解原则 maven 自动按照下边的原则调解: 第一声明者优先原则 在 pom 文件定义依赖,先声明的依赖为准。...排除依赖 上边的问题也可以通过排除依赖方法辅助依赖调解,如下:比如在依赖 spring-webmvc 的设置中添加排除依赖,排除 spring-beans,下边的配置表示:依赖 spring-webmvc...锁定版本 面对众多的依赖,有一种方法不用考虑依赖路径、声明优化等因素可以采用直接锁定版本的方法确定依赖构件的版本,版本锁定后则不考虑依赖的声明顺序或依赖的路径,以锁定的版本的为准添加到工程中,此方法在企业开发中常用

78310

maven: 打包可运行的jar包(java application)及依赖处理

IDE环境中,可以直接用exec-maven-plugin插件来运行java application,类似下面这样: 1 2 org.codehaus.mojo...环境,只能用 java -jar xxx.jar这种方式来运行,下面是一些处理细节: 一、依赖的处理 java application运行时需要查找依赖的第三方jar,如果查找classpath失败,...就会报错,可以先用 mvn dependency:copy-dependencies -DoutputDirectory=target/lib 命令,把依赖的jar包全部导出到target/lib这个目录下...Main-Class: ctas.importer.reader.app.Program 7 Archiver-Version: Plexus Archiver 其中第4行指定了classpath,也就是所依赖的...> 15 第7行指定Main-Class,第9行指定classpath的相对路径,这样mvn package后,清单文件里就会自动添加Main-Class和Class-Path这二

1.9K90
领券