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