Springboot項目瘦身之如何將jar包與lib依賴分開打包
將jar包與lib依賴分開打包
方法一:項目和依賴完全分離
maven-jar-plugin 負(fù)責(zé)生成 jar 文件(jar文件中不包含如何依賴),并為 jar 文件的 manifest.mf 文件配置相關(guān)內(nèi)容;maven-dependency-plugin 插件用于在構(gòu)建時將項目的運行時依賴項復(fù)制到指定目錄。
部署項目時,生產(chǎn)的jar文件要和lib依賴包在同一目錄下。
<build>
<!-- 生成的jar名稱 -->
<finalName>${project.artifactId}</finalName>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
<configuration>
<archive>
<!-- 生成的jar中不要包含pom.xml和pom.properties這兩個文件 -->
<addMavenDescriptor>false</addMavenDescriptor>
<manifest>
<addClasspath>true</addClasspath>
<classpathPrefix>lib/</classpathPrefix>
<!--這里需要修改為你的項目的主啟動類-->
<mainClass>你的啟動類路徑</mainClass>
<!-- 是否使用唯一版本號,控制 MANIFEST.MF 中類路徑的版本格式;如果不加,可能會出現(xiàn)依賴后面加時間戳-->
<useUniqueVersions>false</useUniqueVersions>
</manifest>
</archive>
</configuration>
</plugin>
<!--拷貝依賴的jar外面的lib目錄-->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-dependency-plugin</artifactId>
<executions>
<execution>
<id>copy-lib</id>
<phase>package</phase>
<goals>
<goal>copy-dependencies</goal>
</goals>
<configuration>
<!-- 指定依賴拷貝的輸出目錄 -->
<outputDirectory>${project.build.directory}/lib</outputDirectory>
<!-- 不排除傳遞性依賴 -->
<excludeTransitive>false</excludeTransitive>
<!-- 不移除依賴版本號 -->
<stripVersion>false</stripVersion>
<!-- 僅包含 runtime 范圍的依賴 -->
<includeScope>runtime</includeScope>
<!-- 排除 common 和 coo 依賴 -->
<excludeArtifactIds>common,coo</excludeArtifactIds>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>方法二:部分依賴打入jar文件
maven-jar-plugin插件用于生成主 JAR 文件,并配置 MANIFEST.MF 文件中的相關(guān)信息;maven-shade-plugin插件用于將一些特定的依賴項(例如 common 和 coo)打包到主 JAR 文件中,通常用于創(chuàng)建一個"uber JAR"(即包含所有依賴的 JAR);maven-dependency-plugin插件用于在構(gòu)建過程中將除指定依賴(如 common 和 coo)外的其他所有運行時依賴復(fù)制到 lib/ 目錄;
因為maven-jar-plugin會生成一個無依賴的jar文件,所以不需要的情況下可以刪除掉,maven-antrun-plugin 插件用于執(zhí)行一些額外的任務(wù),比如刪除不需要的 JAR 文件。
部署項目時,生產(chǎn)的jar文件要和lib依賴包在同一目錄下。
<build>
<plugins>
<!-- maven-jar-plugin 用于生成主 JAR 文件,并配置 MANIFEST.MF 文件指定lib文件 -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
<executions>
<execution>
<id>default-jar</id>
<phase>package</phase>
<goals>
<goal>jar</goal>
</goals>
</execution>
</executions>
<configuration>
<archive>
<!-- 包中包含 Maven 描述符(如 pom.xml 和 pom.properties 文件) -->
<addMavenDescriptor>true</addMavenDescriptor>
<manifest>
<!-- 在 MANIFEST.MF 中添加類路徑 -->
<addClasspath>true</addClasspath>
<!-- 指定依賴的類路徑前綴為 lib/ -->
<classpathPrefix>lib/</classpathPrefix>
<!-- 指定主啟動類 -->
<mainClass>你的啟動類路徑</mainClass>
<!-- 使用非唯一版本(不在依賴路徑中添加版本號) -->
<useUniqueVersions>false</useUniqueVersions>
</manifest>
</archive>
</configuration>
</plugin>
<!-- maven-shade-plugin 用于將指定依賴(如 common 和 coo)打包進(jìn)主 JAR -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-shade-plugin</artifactId>
<executions>
<execution>
<!-- 在 package 階段執(zhí)行 -->
<phase>package</phase>
<goals>
<!-- 使用 shade 目標(biāo) -->
<goal>shade</goal>
</goals>
<configuration>
<artifactSet>
<!-- 指定需要包含在主 JAR 中的依賴 -->
<includes>
<include>com.test:common</include>
<include>com.test:coo</include>
</includes>
</artifactSet>
<!-- 禁用生成附加的 original-xxx.jar 文件 -->
<shadedArtifactAttached>false</shadedArtifactAttached>
<!-- 禁用生成 dependency-reduced-pom.xml 文件 -->
<createDependencyReducedPom>false</createDependencyReducedPom>
<!-- 自定義最終生成的 JAR 包名稱 -->
<finalName>${project.artifactId}</finalName>
</configuration>
</execution>
</executions>
</plugin>
<!-- maven-dependency-plugin 用于將除 common 和 coo 外的其他依賴拷貝到 lib 文件夾 -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-dependency-plugin</artifactId>
<executions>
<execution>
<!-- 設(shè)置執(zhí)行的 ID -->
<id>copy-lib</id>
<!-- 在 package 階段執(zhí)行 -->
<phase>package</phase>
<goals>
<!-- 使用 copy-dependencies 目標(biāo) -->
<goal>copy-dependencies</goal>
</goals>
<configuration>
<!-- 指定依賴拷貝的輸出目錄 -->
<outputDirectory>${project.build.directory}/lib</outputDirectory>
<!-- 不排除傳遞性依賴 -->
<excludeTransitive>false</excludeTransitive>
<!-- 不移除依賴版本號 -->
<stripVersion>false</stripVersion>
<!-- 僅包含 runtime 范圍的依賴 -->
<includeScope>runtime</includeScope>
<!-- 排除 common 和 coo 依賴 -->
<excludeArtifactIds>common,coo</excludeArtifactIds>
</configuration>
</execution>
</executions>
</plugin>
<!-- maven-antrun-plugin 用于刪除多余的 JAR 文件 -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-antrun-plugin</artifactId>
<executions>
<execution>
<!-- 在 package 階段執(zhí)行 -->
<phase>package</phase>
<configuration>
<tasks>
<!-- 刪除由 maven-jar-plugin 生成的默認(rèn) JAR 文件 -->
<delete file="${project.build.directory}/${project.artifactId}-${project.version}.jar" />
</tasks>
</configuration>
<goals>
<!-- 使用 run 目標(biāo) -->
<goal>run</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>jar文件和lib打包命令
maven-assembly-plugin 配置是用于 Maven 項目的構(gòu)建過程,生成一個壓縮包(tar 或 zip 格式)并將其輸出到指定的目錄
<!--maven-assembly-plugin 用于打包項目生成壓縮文件-->
<plugin>
<!-- 指定使用的插件:maven-assembly-plugin -->
<artifactId>maven-assembly-plugin</artifactId>
<configuration>
<!-- 是否將assembly的ID添加到生成包的名稱中。設(shè)為false時,不會在包名中添加ID。 -->
<appendAssemblyId>false</appendAssemblyId>
<!-- 指定最終生成的tar或zip包的文件名,這里設(shè)置為djys-business。 -->
<finalName>build-jar</finalName>
<!-- 輸出目錄,生成的tar或zip包會存放在target目錄下。 -->
<outputDirectory>target/</outputDirectory>
<descriptors>
<!-- 指定引用的assembly配置文件,這里引用src/main/resources/assembly.xml -->
<descriptor>src/main/resources/assembly.xml</descriptor>
</descriptors>
</configuration>
<executions>
<execution>
<!-- 執(zhí)行ID,可以任意命名,這里使用make-assembly。 -->
<id>make-assembly</id>
<!-- 將該插件綁定到package生命周期階段,當(dāng)執(zhí)行mvn package時會調(diào)用該插件。 -->
<phase>package</phase>
<goals>
<!-- 設(shè)置插件目標(biāo),這里使用single目標(biāo),它會創(chuàng)建單個壓縮包(tar/zip)。 -->
<goal>single</goal>
</goals>
</execution>
</executions>
</plugin>assembly.xml文件內(nèi)容
<assembly xmlns="http://maven.apache.org/ASSEMBLY/3.3.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/ASSEMBLY/3.3.0 http://maven.apache.org/xsd/assembly-3.3.0.xsd">
<id>package</id>
<formats>
<format>zip</format>
</formats>
<includeBaseDirectory>true</includeBaseDirectory>
<fileSets>
<!-- <!–拷貝application.yml文件到j(luò)ar包的外部config目錄下面–>-->
<!-- <fileSet>-->
<!-- <directory>${basedir}/src/main/resources</directory>-->
<!-- <includes>-->
<!-- <include>*.yml</include>-->
<!-- </includes>-->
<!-- <filtered>true</filtered>-->
<!-- <outputDirectory>${file.separator}config</outputDirectory>-->
<!-- </fileSet>-->
<!--拷貝lib包到j(luò)ar包的外部lib下面-->
<fileSet>
<directory>${project.build.directory}/lib</directory>
<outputDirectory>${file.separator}lib</outputDirectory>
<!-- 打包需要包含的文件 -->
<includes>
<include>*.jar</include>
</includes>
</fileSet>
<!--如有需要,可以配置多個需要拷貝的文件即可-->
<fileSet>
<directory>${project.build.directory}</directory>
<outputDirectory>${file.separator}</outputDirectory>
<includes>
<include>*.jar</include>
</includes>
</fileSet>
</fileSets>
</assembly>
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java使用ffmpeg和mencoder實現(xiàn)視頻轉(zhuǎn)碼
這篇文章主要為大家詳細(xì)介紹了Java使用ffmpeg和mencoder實現(xiàn)視頻轉(zhuǎn)碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-12-12
SpringBoot詳解MySQL如何實現(xiàn)讀寫分離
當(dāng)響應(yīng)的瓶頸在數(shù)據(jù)庫的時候,就要考慮數(shù)據(jù)庫的讀寫分離,當(dāng)然還可以分庫分表,那是單表數(shù)據(jù)量特別大,當(dāng)單表數(shù)據(jù)量不是特別大,但是請求量比較大的時候,就要考慮讀寫分離了.具體的話,還是要看自己的業(yè)務(wù)...如果還是很慢,那就要分庫分表了...我們這篇就簡單講一下讀寫分離2022-09-09
基于SpringBoot中activeMq的JmsTemplate的實例
這篇文章主要介紹了基于SpringBoot中activeMq的JmsTemplate的實例問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-07-07
java靈活使用mysql中json類型字段存儲數(shù)據(jù)詳解
在數(shù)據(jù)庫設(shè)計中,面對一對多的關(guān)系,如訂單和商品,可以考慮使用單表存儲而非傳統(tǒng)的分表方式,這篇文章主要介紹了java靈活使用mysql中json類型字段存儲數(shù)據(jù)的相關(guān)資料,需要的朋友可以參考下2024-09-09
Java應(yīng)用程序CPU100%問題排查優(yōu)化實戰(zhàn)
這篇文章主要介紹了如何排查和優(yōu)化Java應(yīng)用程序CPU使用率達(dá)到100%的問題,文中通過代碼示例和圖文結(jié)合的方式講解的非常詳細(xì),具有一定的參考價值,需要的朋友可以參考下2025-02-02

