maven打全量包-使用scope排除不需要打包的依赖

maven打全量包-使用scope排除不需要打包的依赖问题背景 生产环境缺少一些依赖 导致程序无法运行 打全量包耗时而且有 jar 包冲突的风险 需要一种方法只把生产环境缺少的依赖打进去 生产环境有的依赖就不打进去 需要排除 解决方案 使用 maven 全量包插件和依赖的作用域 scope 属性可以实现指定依赖打进 jar 包

大家好,我是讯享网,很高兴认识大家。
  • 问题背景

生产环境缺少一些依赖,导致程序无法运行,打全量包耗时而且有jar包冲突的风险,需要一种方法只把生产环境缺少的依赖打进去,生产环境有的依赖就不打进去(需要排除)

  • 解决方案

使用maven全量包插件和依赖的作用域(scope)属性可以实现指定依赖打进jar包

maven全量包插件配置如下:

<build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <configuration> <source>8</source> <target>8</target> </configuration> </plugin> <plugin> <artifactId>maven-assembly-plugin</artifactId> <configuration> <descriptorRefs> <descriptorRef>jar-with-dependencies</descriptorRef> </descriptorRefs> </configuration> <executions> <execution> <id>make-assembly</id> <phase>package</phase> <goals> <goal>single</goal> </goals> </execution> </executions> </plugin> </plugins> </build>

讯享网

使用上面的maven全量包插件打包会把依赖的所有包都打进去,这时候不需要打包的依赖可以将scope属性设置成provided,如下图所示:

讯享网<dependency> <groupId>org.apache.flink</groupId> <artifactId>flink-streaming-java_2.11</artifactId> <version>${flink.version}</version> <scope>provided</scope> </dependency>

这样打包完后会产生两个jar包,一大一小,大的就是包含依赖的,小的就不包含任何依赖,如下图:


讯享网

 

IDEA中,如果依赖的scope值设置为了provided,本地运行可能会报错找不到类,这时可以看看此处是否勾选上了:

小讯
上一篇 2025-04-03 21:23
下一篇 2025-03-13 20:01

相关推荐

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请联系我们,一经查实,本站将立刻删除。
如需转载请保留出处:https://51itzy.com/kjqy/41738.html