springboot打war包的全過程記錄
為什么要把SpringBoot打成war包
正常情況下SpringBoot項目是以jar包的形式,通過命令行:
java -jar demo.jar
來運行的,并且SpringBoot是內(nèi)嵌Tomcat服務(wù)器,所以每次重新啟動都是用的新的Tomcat服務(wù)器。正因如此,也出現(xiàn)了一個問題:
上傳到項目的文件,如果是保存在項目中的,那么重啟過后文件就會丟失。比如我們上傳了一個頭像,重啟項目后,這個頭像就沒了。而如果將文件保存在本地磁盤中的話,html中標(biāo)簽沒辦法獲取(當(dāng)然,企業(yè)項目中一般是有專門的圖片服務(wù)器的)。因此,我們才需要將SpringBoot項目打成war包,放到Tomcat中去運行。
springboot打war包
默認(rèn)場景下,Springboot作為一個jar運行,但是在某些特殊場景下 需要將后臺和其他應(yīng)用共用一個web容器(tomcat之類);
客戶強制要求(例如策略只給了一個端口);
其他;
可以打包成war文件進(jìn)行發(fā)布。
分步指南
一般情況下,將springboot工程打包為war分為以下幾個步驟:
修改pom.xml,將打包方式設(shè)置為war 修改jar為war
移除springboot默認(rèn)的tomcat配置
移除默認(rèn)的spring-boot-starter-tomcat,使用provided
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
<scope>provided</scope>
</dependency>
添加tomcat-servelt-api依賴
*注意根據(jù)自己的情況修改version
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>3.1.0</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>org.apache.tomcat</groupId>
<artifactId>tomcat-servlet-api</artifactId>
<version>8.0.36</version>
<scope>provided</scope>
</dependency>
修改啟動方法
增加configure配置
@SpringBootApplication
public class ServerApplication extends SpringBootServletInitializer {
@Override
protected SpringApplicationBuilder configure(SpringApplicationBuilder builder) {
return builder.sources(ServerApplication.class);
}
public static void main(String[] args) {
SpringApplication.run(ServerApplication.class, args);
}
}
添加打包插件
在pom.xml的build > plugins 中添加打包插件,可以指定打包的名稱等配置
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-war-plugin</artifactId>
<configuration>
<warSourceExcludes>src/main/resources/**</warSourceExcludes>
<warName>yehuo</warName>
<failOnMissingWebXml>false</failOnMissingWebXml>
</configuration>
</plugin>
修改項目的context-path與warName一致 修改application.properties的context-path和port等信息和實際部署的情況改為一致
server.port=server.context-path=yehuo
總結(jié)
到此這篇關(guān)于springboot打war包的文章就介紹到這了,更多相關(guān)springboot打war包內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java實戰(zhàn)寵物店在線交易平臺的實現(xiàn)流程
讀萬卷書不如行萬里路,只學(xué)書上的理論是遠(yuǎn)遠(yuǎn)不夠的,只有在實戰(zhàn)中才能獲得能力的提升,本篇文章手把手帶你用java+Springboot+maven+Mysql+FreeMarker實現(xiàn)一個寵物在線交易系統(tǒng),大家可以在過程中查缺補漏,提升水平2022-01-01
Java Validation Api如何實現(xiàn)自定義注解
這篇文章主要介紹了Java Validation Api如何實現(xiàn)自定義注解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-09-09
Spring 靜態(tài)變量/構(gòu)造函數(shù)注入失敗的解決方案
我們經(jīng)常會遇到一下問題:Spring對靜態(tài)變量的注入為空、在構(gòu)造函數(shù)中使用Spring容器中的Bean對象,得到的結(jié)果為空。不要擔(dān)心,本文將為大家介紹如何解決這些問題,跟隨小編來看看吧2021-11-11
SpringBoot Jpa 自定義查詢實現(xiàn)代碼詳解
這篇文章主要介紹了SpringBoot Jpa 自定義查詢實現(xiàn)代碼詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-02-02
Spring Boot 3.4.0 結(jié)合 Mybatis-plus 實
本文詳細(xì)介紹了在 Spring Boot 3.4.0 項目中結(jié)合 Mybatis-plus 實現(xiàn)動態(tài)數(shù)據(jù)源切換的完整方案,通過自定義注解和AOP切面,我們可以優(yōu)雅地實現(xiàn)方法級別的數(shù)據(jù)源切換,滿足多數(shù)據(jù)源場景下的各種需求,感興趣的朋友一起看看吧2025-04-04

