最近在做 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 中已经提供的包排除在外,去掉重复的打包过程.
欢迎来到这里!
我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。
注册 关于