一.手动上传jar包部署
默认情况下,Spring Boot 项目发布时会将项目代码和项目的所有依赖文件一起打成一个可执行的 jar 包。但如果项目的依赖包很多,那么这个文件就会非常大。这样每次即使只改动一点东西,就需要将整个项目重新打包部署,从jar包中分离出依赖包lib和资源文件,方便对线上资源进行维护,这样每次部署只需要发布项目源码即可。
1、配置pom文件进行jar包瘦身
参考:SpringBoot打包分离lib和资源文件并使用Dockerfile构建Docker镜像
1、排除SpringBoot jar包中的其他依赖包
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<layout>ZIP</layout>
<!-- 打包时只包含指定的依赖包 -->
<includes>
<!-- jar中不包含其他依赖包 -->
<include>
<groupId>nothing</groupId>
<artifactId>nothing</artifactId>
</include>
<!-- <include>
<groupId>cn.hutool</groupId>
<artifactId>hutool-all</artifactId>
</include> -->
</includes>
<!-- 打包时去除指定的依赖包 -->
<!-- <excludes>
<exclude>
<groupId>cn.hutool</groupId>
<artifactId>hutool-all</artifactId>
</exclude>
</excludes> -->
</configuration>
<!-- 默认goal,可忽略。在mvn package之后,再次打包可执行的jar/war,同时保留mvn package生成的jar/war为.origin -->
<executions>
<execution>
<goals>
<goal>repackage</goal>
</goals>
</execution>
</executions>
</plugin>
2、拷贝依赖包到指定目录
<!-- 个人认为只需要在第一次运行的时候加上此插件,在去掉之后,将新加的依赖的jar包手动复制到此目录下即可 -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-dependency-plugin</artifactId>
<executions>
<execution>
<id>copy-dependency</id>
<phase>package</phase>
<goals>
<goal>copy-dependencies</goal>
</goals>
<configuration>
<!--输出目录 -->
<!-- ${project.build.directory}为Maven内置变量,缺省为target -->
<outputDirectory>${project.build.directory}/lib</outputDirectory>
<!-- 表示是否不包含间接依赖的包 -->
<excludeTransitive>false</excludeTransitive>
<!-- 表示复制的jar文件去掉版本信息 -->
<stripVersion>false</stripVersion>
<!-- <includeScope>runtime</includeScope> 不知道作用,先放着-->
</configuration>
</execution>
</executions>
</plugin>
3、拷贝资源文件到指定目录
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
<configuration>
<archive>
<!-- 生成的jar中,不要包含pom.xml和pom.properties这两个文件 -->
<addMavenDescriptor>false</addMavenDescriptor>
<manifest>
<!-- 是否要把第三方jar加入到类构建路径 -->
<addClasspath>true</addClasspath>
<!-- 外部依赖jar包的最终位置 -->
<classpathPrefix>lib/</classpathPrefix>
<!-- 配置项目启动类 -->
<mainClass>com.ModeloneApplication</mainClass>
</manifest>
<!-- 指定配置文件的新目录,如果没有使用maven-resources-plugin插件,该配置项可忽略 -->
<manifestEntries>
<Class-Path>resources/</Class-Path>
</manifestEntries>
</archive>
<excludes>
<!--以target/classes为根目录-->
<!--资源文件排除-->
<exclude>/*.*</exclude>
<!--html页面排除-->
<exclude>/templates/</exclude>
<!--静态文件排除-->
<exclude>/static/</exclude>
</excludes>
</configuration>
</plugin>
4、jar包指定资源和依赖包的路径并从Springboot jar包中排除原有资源
<!--指定配置文件-->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
<configuration>
<archive>
<!-- 生成的jar中,不要包含pom.xml和pom.properties这两个文件 -->
<addMavenDescriptor>false</addMavenDescriptor>
<manifest>
<!-- 是否要把第三方jar加入到类构建路径 -->
<addClasspath>true</addClasspath>
<!-- 外部依赖jar包的最终位置 -->
<classpathPrefix>lib/</classpathPrefix>
<!-- 配置项目启动类 -->
<mainClass>gateway.GatewayApplication</mainClass>
</manifest>
<!-- 指定配置文件的新目录,如果没有使用maven-resources-plugin插件,该配置项可忽略 -->
<manifestEntries>
<Class-Path>resources/</Class-Path>
</manifestEntries>
</archive>
<excludes>
<!--以target/classes为根目录-->
<!--资源文件排除-->
<exclude>/*.*</exclude>
<!--html页面排除-->
<exclude>/templates/</exclude>
<!--静态文件排除-->
<exclude>/static/</exclude>
</excludes>
</configuration>
</plugin>
至此Springboot jar包瘦身配置完成
2、mvn打包查看瘦身结果
1、target目录
生成了lib和resource文件
2、jar包中
生成的jar包中排除了lib和资源文件
3、执行jar查看
在jar包所在目录执行
二.使用工具(jenkins等)自动部署
一、前言
SpringBoot部署起来虽然简单,如果服务器部署在公司内网,速度还行,但是如果部署在公网(阿里云等云服务器上),部署起来实在头疼:编译出来的 Jar 包很大,如果工程引入了许多开源组件(SpringCloud等),那就更大了。
这个时候如果想要对线上运行工程有一些微调,则非常痛苦
二、瘦身前的Jar包
Tomcat在部署Web工程的时候,可以进行增量更新,SpringBoot也是可以的~
SpringBoot编译出来的Jar包中,磁盘占用大的,是一些外部依赖库(jar包),例如:
进入项目工程根目录,执行 mvn clean install 命令,得到的Jar包,用压缩软件打开,目录结构如下:
整个Jar包 18.18 MB, 但是 BOOT-INF/lib 就占用了将近 18 MB:
三、解决方法
步骤1: 正常编译JAR包,解压出lib文件夹
POM文件如下:
进入项目根目录,执行命令:mvn clean install
将编译后的Jar包解压,拷贝 BOOT-INF 目录下的lib文件夹 到目标路径;
步骤2: 修改pom.xml配置,编译出不带 lib 文件夹的Jar包
配置完成后,再次执行编译:mvn clean install
生成的 Jar 包体积明显变小,如下所示, 外部的 jar 包已经不会被引入了:
步骤3: 运行编译后的Jar包
将 步骤1 解压出来的lib文件夹、步骤2编译的jar包放在同一个目录, 运行下面命令:
或者在maven中输入一下命令导出需要用到的jar包
备注:
将/path/to/改成实际的路径。
-Dloader.path=lib文件夹路径
最终目录文件结构是:
说明
1、通常,一个工程项目架构确定后,引入的jar包基本上不会变,改变的大部分是业务逻辑;
2、后面如果需要变更业务逻辑,只需要轻量地编译工程,大大提高项目部署的效率。