Maven 打包忽略依赖jar包之
1. 背景
- 作为事实上主流的jar包管理工具,有时候需要考虑工程打包是否包含所依赖jar包,这样可以缩减打出来的bar大小
- 实际maven打包,如果在pom文件中配置了打包插件,就会打出2个jar包,一个是包含依赖的jar包,一个是不包含依赖的jar包。
- 不包含依赖的jar包,体积会小很多,只包含编写的逻辑代码,但要求这个jar包运行环境中必须有这些依赖jar包。
- 包含依赖的jar包,只要有jre 运行环境,就可以运行,因为已经把所依赖的jar包都打进去了,对外部没有依赖。但体积会相应大很多。


这里可以看出,original开头的是原始包,也就是不包含依赖jar包的工程包。
- 所以,2种打包方式都存在,但需要根据情况进行选择。在很多情况下,为了追求jar包体积精简,有时候就会采取不带依赖进行打包。
- maven其实也提供了针对单个jar包是否打进工程包中的选项
2. 如何处理
<dependency>
<groupId>org.apache.spark</groupId>
<artifactId>spark-core_2.12</artifactId>
<version>${spark.version}</version>
<!-- 编译时会引入依赖,打包是不引入依赖 -->
<scope>provided</scope>
</dependency>
上述配置中,provided加上这一个配置项,编译时会引入这个依赖,但打包是不会依赖。
这样就可以保证编译时不会因为找不到jar包而报错,但打出来的jar包就不会引入这个jar包,就可以针对单个jar包粒度做是否打进工程包做控制。
注意,如果无法保证工程打出来的包中运行环境是否包含所依赖jar,建议最好都打成依赖包,先解决是否可以跑起来的问题,如有必要再考虑jar包体积大的问题。

本文介绍了在Maven中如何在打包时忽略特定的依赖jar包,以减小最终jar的体积。通过在pom.xml文件中配置打包插件,可以创建包含和不包含依赖的两种jar包。使用<scope>provided</scope>可以确保编译时引入依赖,但在打包时不包含该依赖。在选择打包方式时,应根据实际运行环境是否有相关依赖来决定。
2321

被折叠的 条评论
为什么被折叠?



