详解SpringBoot迭代发布JAR瘦身配置
作者:田心双木
这篇文章主要介绍了详解SpringBoot迭代发布JAR瘦身配置,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
默认情况下,插件 spring-boot-maven-plugin 会把整个项目打包成一个可运行的Jar包(即所谓的Flat Jar),导致了这个Jar包很大(通常有几十M+)。如今迭代发布时常有的事情,每次都上传一个如此庞大的文件,会浪费很多时间,有些时候上传的过程中还会出错。
造成Jar包很大的根本原因就是依赖第三方的jar很多,很大,下面我们就把第三方的JAR与项目代码分离,第三方的JAR把移除到lib文件夹中,即可实现为我们的可执行JAR瘦身,配置如下:
<plugins> <!-- spring boot thin jar configuration --> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> <configuration> <!-- main 入口 --> <mainClass>com.bdfint.logistics.app.driver.LogisticsAppDriverApplication</mainClass> <!-- 设置为ZIP,此模式下spring-boot-maven-plugin会将Manifest.MF文件中的Main-Class设置为org.springframework.boot.loader.PropertiesLauncher --> <layout>ZIP</layout> <!-- 需要包含的jar包 --> <includes> <!-- 不包含任何jar包 --> <!--<include>--> <!--<groupId>nothing</groupId>--> <!--<artifactId>nothing</artifactId>--> <!--</include>--> <include> <groupId>com.bdfint.logistics</groupId> <artifactId>logistics-api</artifactId> </include> <include> <groupId>com.bdfint.logistics</groupId> <artifactId>logistics-common</artifactId> </include> </includes> </configuration> <executions> <execution> <goals> <goal>repackage</goal> </goals> </execution> </executions> </plugin> <!-- third-party jar into lib directory --> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-dependency-plugin</artifactId> <executions> <execution> <id>copy-dependencies</id> <phase>prepare-package</phase> <goals> <goal>copy-dependencies</goal> </goals> <configuration> <outputDirectory>${project.build.directory}/lib</outputDirectory> <!-- 需要排除的jar的 groupId --> <excludeGroupIds> com.bdfint.logistics </excludeGroupIds> </configuration> </execution> </executions> </plugin> </plugins>
接下来,执行打包命令:mvn clean package -Dmaven.test.skip=true,打包后在target目录下就包含我们的JAR和lib目录,如下图:
CMD定位到target目录下,执行命令:java -Dloader.path=./lib -jar logistics-app-driver-2.9.1.1.jar,即可把项目JAR跑起来!
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。