- 问题背景
生产环境缺少一些依赖,导致程序无法运行,打全量包耗时而且有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,本地运行可能会报错找不到类,这时可以看看此处是否勾选上了:


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