目錄:
1.前言
2.瘦身前的Jar包
3.解決方案
一、前言
SpringBoot部署起來雖然簡單,如果服務器部署在公司內網,速度還行,但是如果部署在公網(阿里雲等雲服務器上),部署起來實在頭疼:編譯出來的 Jar 包很大,如果工程引入了許多開源組件(SpringCloud等),那就更大了。
這個時候如果想要對線上運行工程有一些微調,則打包部署非常痛苦。
二、瘦身前的Jar包
Tomcat在部署Web工程的時候,可以進行增量更新,SpringBoot也是可以的。
SpringBoot編譯出來的Jar包中,磁盤占用大的,大部分是一些外部依賴庫(jar包), 進入項目工程根目錄,執行 mvn clean package 命令,得到的Jar包,用壓縮軟件打開,目錄結構如下:
整個Jar包 66.6 MB, 但是 BOOT-INF/lib 就占用了將近 66.4 MB。
三、解決方法
步驟1: 正常編譯JAR包,解壓出lib文件夾
POM文件如下:
<build> <plugins> <!--這個插件是將所有的包打在一起--> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> <plugin> <!-- 這個插件主要是對打的包解壓到dependency目錄下 --> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-dependency-plugin</artifactId> <executions> <execution> <id>unpack</id> <phase>package</phase> <goals> <goal>unpack</goal> </goals> <configuration> <artifactItems> <artifactItem> <groupId>${project.groupId}</groupId> <artifactId>${project.artifactId}</artifactId> <version>${project.version}</version> </artifactItem> </artifactItems> </configuration> </execution> </executions> </plugin> <!-- 根據 dockerfile 構建鏡像的mvn插件 --> <plugin> <groupId>com.spotify</groupId> <artifactId>dockerfile-maven-plugin</artifactId> <version>1.4.9</version> <configuration> <!-- 鏡像名 --> <repository>${docker.image.prefix}/${project.artifactId}</repository> <!-- tag:默認使用當前版本 --> <tag>${project.version}</tag> </configuration> </plugin> </plugins> <!--資源文件拷貝--> <resources> <resource> <directory>src/main/java</directory> <includes> <include>**/*.xml</include> </includes> </resource> <resource> <directory>src/main/resources</directory> <includes> <include>**/**</include> </includes> </resource> </resources> </build>
進入項目根目錄,執行命令:mvn clean package ,將編譯后的Jar包解壓,拷貝 BOOT-INF 目錄下的lib文件夾 到目標路徑。
步驟2: 修改pom.xml配置,編譯出不帶 lib 文件夾的Jar包
<build> <plugins> <!--這個插件是將所有的包打在一起--> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> <configuration> <mainClass>com.zsm.JDApplication</mainClass> <layout>ZIP</layout> <includes> <include> <groupId>nothing</groupId> <artifactId>nothing</artifactId> </include> </includes> </configuration> </plugin> <plugin> <!-- 這個插件主要是對打的包解壓到dependency目錄下 --> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-dependency-plugin</artifactId> <executions> <execution> <id>unpack</id> <phase>package</phase> <goals> <goal>unpack</goal> </goals> <configuration> <artifactItems> <artifactItem> <groupId>${project.groupId}</groupId> <artifactId>${project.artifactId}</artifactId> <version>${project.version}</version> </artifactItem> </artifactItems> </configuration> </execution> </executions> </plugin> <!-- 根據 dockerfile 構建鏡像的mvn插件 --> <plugin> <groupId>com.spotify</groupId> <artifactId>dockerfile-maven-plugin</artifactId> <version>1.4.9</version> <configuration> <!-- 鏡像名 --> <repository>${docker.image.prefix}/${project.artifactId}</repository> <!-- tag:默認使用當前版本 --> <tag>${project.version}</tag> </configuration> </plugin> </plugins> <!--資源文件拷貝--> <resources> <resource> <directory>src/main/java</directory> <includes> <include>**/*.xml</include> </includes> </resource> <resource> <directory>src/main/resources</directory> <includes> <include>**/**</include> </includes> </resource> </resources> </build>
配置完成后,再次執行編譯:mvn clean package ,生成的 Jar 包體積明顯變小,如下所示, 外部的 jar 包已經不會被引入了:
步驟3: 運行編譯后的Jar包
將 步驟1 解壓出來的lib文件夾、步驟2編譯的jar包放在同一個目錄, 運行下面命令:
java -Dloader.path=D:/test/lib -jar D:/test/jenkins-docker-1.0-SNAPSHOT.jar
或者在maven中輸入一下命令導出需要用到的jar包
mvn dependency:copy-dependencies -DoutputDirectory=D:/test/lib -DincludeScope=runtimme
備注:
將 D:/test/ 改成實際的路徑。
-Dloader.path=lib文件夾路徑
最終目錄文件結構是:
lib #lib 文件夾
jenkins-docker-1.0-SNAPSHOT.jar #jar包
說明
1、通常,一個工程項目架構確定后,引入的jar包基本上不會變,改變的大部分是業務邏輯,如果pom依賴發生了變化,必須替換原來的 lib 依賴文件;
2、后面如果需要變更業務邏輯,只需要輕量地編譯工程,大大提高項目部署的效率。
參考:https://mp.weixin.qq.com/s/8gWrYfAfkZ7KoFkhg6ZWvA