Spring Boot jar中沒有主清單屬性的解決方法
使用Spring Boot微服務搭建框架,在eclipse和Idea下能正常運行,但是在打成jar包部署或者直接使用java -jar命令的時候,提示了xxxxxx.jar中沒有主清單屬性:
D:\hu-git\spring-xxx-xxx\target>java -jar spring-cloud-eureka-0.0.1-SNAPS
HOT.jar
spring-xxx-xxx-0.0.1-SNAPSHOT.jar中沒有主清單屬性
通過maven打jar包:mvn install, 或者在IDE中右擊選擇Run as -> maven install。
在這里有一個問題就是主清單屬性是什么?
以SpringBoot為例,jar包中包含了三個文件夾:BOOT-INF,META-INF,org,可以把jar包解壓到文件夾下查看,其中META-INF文件夾下有一個MANIFEST.MF文件,該文件指明了程序的入口以及版本信息等內(nèi)容,如下
Manifest-Version: 1.0 Implementation-Title: spring-xxx-xxx Implementation-Version: 0.0.1-SNAPSHOT Archiver-Version: Plexus Archiver Built-By: XXXX Implementation-Vendor-Id: com.huyikang.practice Spring-Boot-Version: 1.5.9.RELEASE Implementation-Vendor: Pivotal Software, Inc. Main-Class: org.springframework.boot.loader.JarLauncher Start-Class: com.huyikang.practice.eureka.Application Spring-Boot-Classes: BOOT-INF/classes/ Spring-Boot-Lib: BOOT-INF/lib/ Created-By: Apache Maven 3.5.2 Build-Jdk: 1.8.0_151 Implementation-URL: http://maven.apache.org
- Main-Class代表了Spring Boot中啟動jar包的程序
- Start-Class屬性就代表了Spring Boot程序的入口類,這個類中應該有一個main方法
- Spring-Boot-Classes代表了類的路徑,所有編譯后的class文件,以及配置文件,都存儲在該路徑下
- Spring-Boot-Lib表示依賴的jar包存儲的位置
這些值都是SpringBoot打包插件會默認生成的,如果沒有這些屬性,SpringBoot程序自然不能運行,就會報錯:jar中沒有主清單屬性,也就是說沒有按照SpringBoot的要求,生成這些必須的屬性。
解決辦法:
在pom中添加一個SpringBoot的構(gòu)建的插件,然后重新運行 mvn install即可。
<build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build>
在運行mvn install的時候,自動生成這些主清單屬性,運行java -jar xxx.jar時會根據(jù)主清單屬性找到啟動類,從而啟動程序。
到此這篇關(guān)于Spring Boot jar中沒有主清單屬性的解決的文章就介紹到這了,更多相關(guān)Spring Boot jar 主清單屬性內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java自定義過濾器和攔截器實現(xiàn)ThreadLocal線程封閉
本文主要介紹了Java自定義過濾器和攔截器實現(xiàn)ThreadLocal線程封閉,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-08-08
Kafka單節(jié)點偽分布式集群搭建實現(xiàn)過程詳解
這篇文章主要介紹了Kafka單節(jié)點偽分布式集群搭建實現(xiàn)過程詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-11-11
SparkSQL中的JSON內(nèi)置函數(shù)全解析
你是否曾經(jīng)為處理JSON數(shù)據(jù)而頭疼?SparkSQL為我們提供了強大的內(nèi)置JSON函數(shù),讓JSON處理變得輕而易舉,本文將帶你深入了解這些函數(shù),感興趣的朋友一起看看吧2024-08-08

