知行

总结之后必有收获 开始使用

maven 中 scope 标签详解

最近在做 pom 优化工作,发现对于 maven 依赖管理中的 scope 标签还是有不明白的地方,所以今天就来总结一下这方面的知识,scope 在 maven 的依赖管理中主要负责项目的部署

maven 的哲学在上次技术分享的时候也提到了:约定大于配置,所以在 maven 中,很多内容都有默认值,scope 的默认值是 compile,那么 scope 还能有哪些选项呢?

scope 的分类

1.compile:默认值 他表示被依赖项目需要参与当前项目的编译,还有后续的测试,运行周期也参与其中,是一个比较强的依赖。打包的时候通常需要包含进去

2.test:依赖项目仅仅参与测试相关的工作,包括测试代码的编译和执行,不会被打包,例如:junit

3.runtime:表示被依赖项目无需参与项目的编译,不过后期的测试和运行周期需要其参与。与 compile 相比,跳过了编译而已。例如 JDBC 驱动,适用运行和测试阶段

4.provided:打包的时候可以不用包进去,别的设施会提供。事实上该依赖理论上可以参与编译,测试,运行等周期。相当于 compile,但是打包阶段做了 exclude 操作

5.system:从参与度来说,和 provided 相同,不过被依赖项不会从 maven 仓库下载,而是从本地文件系统拿。需要添加 systemPath 的属性来定义路径

scope 的依赖传递

A 依赖 B,B 依赖 C。当前项目为 A,只当 B 在 A 项目中的 scope,那么 c 在 A 中的 scope 是如何得知呢?

当 C 是 test(注意test)或者 provided 时,C 直接被丢弃,A 不依赖 C;(排除传递依赖)

否则 A 依赖 C,C 的 scope 继承与 B 的 scope

所以在优化过程中,我们把项目中的一部分依赖,加上了 scope->provided 标签,也就是说,避免了最后打包阶段把一些可以从 ear 中已经提供的包排除在外,去掉重复的打包过程。

评论
留下你的脚步
推荐阅读