Maven實現(xiàn)把項目依賴的所有jar包都打到同一個jar中
1 使用maven-shade-plugin
(1) 在項目的pom.xml文件中加入如下插件:
<build>
<plugins>
<!-- Maven Shade Plugin -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-shade-plugin</artifactId>
<version>3.2.0</version>
<configuration>
<createDependencyReducedPom>true</createDependencyReducedPom>
</configuration>
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>shade</goal>
</goals>
<configuration>
<transformers>
<transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
<!-- 主類的全限定名 -->
<mainClass>com.healchow.consumer.Main</mainClass>
</transformer>
</transformers>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
(2) 然后使用Maven的package命令打包項目;
(3) 打包完成后, 即可在項目的target目錄下看到生成的jar包;
(4) 不出差錯的話, 使用java -jar xxxx.jar命令即可運行此jar包.
說明: 此方法在Mac OS系統(tǒng)下的IDEA中實施, 在jar/META-INF/目錄下有時會出現(xiàn):
ECLIPSEF.SF ECLIPSE.RSA等文件, 并在運行java -jar xxx.jar時, 會拋出如下錯誤:
Error: A JNI error has occurred, please check your installation and try again
Exception in thread "main" java.lang.SecurityException: Invalid signature file digest for Manifest main attributes
at sun.security.util.SignatureFileVerifier.processImpl(SignatureFileVerifier.java:330)
at sun.security.util.SignatureFileVerifier.process(SignatureFileVerifier.java:263)
at java.util.jar.JarVerifier.processEntry(JarVerifier.java:318)
at java.util.jar.JarVerifier.update(JarVerifier.java:230)
at java.util.jar.JarFile.initializeVerifier(JarFile.java:383)
at java.util.jar.JarFile.getInputStream(JarFile.java:450)
at sun.misc.URLClassPath$JarLoader$2.getInputStream(URLClassPath.java:977)
at sun.misc.Resource.cachedInputStream(Resource.java:77)
at sun.misc.Resource.getByteBuffer(Resource.java:160)
at java.net.URLClassLoader.defineClass(URLClassLoader.java:454)
at java.net.URLClassLoader.access$100(URLClassLoader.java:73)
at java.net.URLClassLoader$1.run(URLClassLoader.java:368)
at java.net.URLClassLoader$1.run(URLClassLoader.java:362)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:361)
at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:335)
at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
at sun.launcher.LauncherHelper.checkAndLoadMain(LauncherHelper.java:495)
解決辦法是: 手動刪除jar包中META-INF/*.RSA META-INF/*.DSA META-INF/*.SF這些文件, 然后就可行了.
2 推薦: 使用maven-assembly-plugin
(1) 在項目的pom.xml文件中加入如下插件:
<build>
<plugins>
<!-- Maven Assembly Plugin -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-assembly-plugin</artifactId>
<version>2.4.1</version>
<configuration>
<!-- get all project dependencies -->
<descriptorRefs>
<descriptorRef>jar-with-dependencies</descriptorRef>
</descriptorRefs>
<!-- MainClass in mainfest make a executable jar -->
<archive>
<manifest>
<mainClass>com.healchow.consumer.Main</mainClass>
</manifest>
</archive>
</configuration>
<executions>
<!-- 配置執(zhí)行器 -->
<execution>
<id>make-assembly</id>
<!-- 綁定到package命令的生命周期上 -->
<phase>package</phase>
<goals>
<!-- 只運行一次 -->
<goal>single</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
(2) 然后使用Maven的package命令打包項目;
(3) 打包完成后, 即可在項目的target目錄下看到生成的jar包, 其中xxx-jar-with-dependencies.jar是包含依賴jar包的jar文件, 另一個不包含依賴jar包;
(4) 使用java -jar xxxx.jar命令即可運行此jar包.
3 擴展: Maven安裝本地jar包到本地倉庫
命令如下:
mvn install:install-file -Dfile=base-util-1.0.RELEASE.jar -DgroupId=com.healchow -DartifactId=base-util -Dversion=1.0.RELEASE -Dpackaging=jar
其他命令, 參考這篇文章: Maven常用命令.
4 擴展: 手動生成jar包
創(chuàng)建可執(zhí)行 jar 包的關鍵在于:讓java -jar命令知道 jar 包中的主方法屬于哪個類 —— 要配置主類的全限定名.
步驟如下:
(1) 打包指定的項目:
進入項目所在的根目錄, 以Linux系統(tǒng)為例:
項目名是java-test, 其所在的目錄是/data/project/java-test;
main方法所屬的類的全限定名是com.healchow.test.Main:
# 進入項目所在的根目錄: cd /data/project # 運行打包命令: jar cvfe test.jar java-test.com.healchow.test.Main java-test
上述命令說明: 將java-test目錄下的所有文件打包到test.jar中, 并指定主類的全限定名稱, 這里要指明主類所在的文件夾.
關于jar命令的其他用法, 參考如下:
# 用法: jar {ctxui}[vfmn0PMe] [jar-file] [manifest-file] [entry-point] [-C dir] files ...
# 選項:
-c 創(chuàng)建新檔案
-t 列出檔案目錄
-x 從檔案中提取指定的 (或所有) 文件
-u 更新現(xiàn)有檔案
-v 在標準輸出中生成詳細輸出
-f 指定檔案文件名
-m 包含指定清單文件中的清單信息
-n 創(chuàng)建新檔案后執(zhí)行 Pack200 規(guī)范化
-e 為捆綁到可執(zhí)行 jar 文件的獨立應用程序指定應用程序入口點
-0 僅存儲; 不使用任何 ZIP 壓縮
-P 保留文件名中的前導 '/' (絕對路徑) 和 ".." (父目錄) 組件
-M 不創(chuàng)建條目的清單文件
-i 為指定的 jar 文件生成索引信息
-C 更改為指定的目錄并包含以下文件
# 如果任何文件為目錄, 則對其進行遞歸處理。
# 清單文件名, 檔案文件名和入口點名稱的指定順序 與 'm', 'f' 和 'e' 標記的指定順序相同。
示例 1: 將兩個類文件歸檔到一個名為 classes.jar 的檔案中:
jar cvf classes.jar Foo.class Bar.class
示例 2: 使用現(xiàn)有的清單文件 'mymanifest' 并將 foo/ 目錄中的所有文件歸檔到 'classes.jar' 中:
jar cvfm classes.jar mymanifest -C foo/ .
(2) 運行jar包:
用解壓軟件打開上一步生成的jar包, 查看META-INF/MANIFEST.MF文件, 里面如果有Main-Class: com.healchow.test.Main, 說明打包成功.
# 在當前目錄下, 運行jar包: java -jar test.jar
5 擴展: Linux下運行jar包的幾種方式
5.1 阻塞式方式
java -jar xxx.jar
特點: 當前終端的會話窗口被阻塞, 可按CTRL + C中斷程序的運行, 或者直接關閉會話窗口 —— 此時jar程序將終止.
5.2 后臺運行方式
# 通過"&"符號實現(xiàn)后臺運行: java -jar xxx.jar &
特點: 當前終端的會話窗口不會被阻塞, 但是如果關閉當前窗口, 程序將終止運行.
5.3 后臺持續(xù)運行方式
# 通過"nohup"命令實現(xiàn)后臺運行: nohup java -jar xxx.jar &
nohup命令是不掛斷運行命令的意思.
特點: 當用戶退出或終端關閉時, 程序的運行不受影響.
說明: 用nohup命令運行任務時, 默認情況下這個任務的所有輸出都將被重定向到nohup.out文件中, 除非另外指定輸出文件. 指定輸出文件方式為:
# 將輸出重定向到xxx.log文件中: nohup java -jar xxx.jar > xxx.log &
> 符號是重定向符, 實現(xiàn): 把它之前命令的所有輸出信息重定向到后面的文件中, 而不是顯示到屏幕上.
5.4 其他命令擴展
① 通過jobs命令可以查看后臺運行任務, 會給每個任務指定一個編號.
② 通過fg命令可以把指定編號的后臺任務調(diào)回到前臺控制, 如: fg 10 —— 把10號任務調(diào)回前臺.
③ 查看占用某個端口的進程:
netstat -nlp | grep 2181 # 下述結果說明進程號pid=18434的java進程占用了2181端口 tcp 0 0 :::2181 :::* LISTEN 18434/java
總結
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
SpringBoot設置首頁(默認頁)跳轉功能的實現(xiàn)方案
這篇文章主要介紹了SpringBoot設置首頁(默認頁)跳轉功能,本文通過兩種方案,給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-07-07
Struts2 ActionContext 中的數(shù)據(jù)詳解
這篇文章主要介紹了Struts2 ActionContext 中的數(shù)據(jù)詳解,需要的朋友可以參考下2016-07-07
Spring Boot定制type Formatters實例詳解
在本篇文章里小編給大家整理的是關于Spring Boot定制type Formatters實例知識點,需要的朋友們學習下。2019-11-11
Spring Cloud OpenFeign實現(xiàn)動態(tài)服務名調(diào)用的示例代碼
在微服務架構中,我們經(jīng)常需要根據(jù)動態(tài)傳入的服務名來遠程調(diào)用其他服務,例如,你的業(yè)務中可能有多個子服務:service-1、service-2……需要動態(tài)決定調(diào)用哪個,所以本文給大家介紹了Spring Cloud OpenFeign 實現(xiàn)動態(tài)服務名調(diào)用指南,需要的朋友可以參考下2025-06-06

