spring boot因?yàn)閮?nèi)嵌tomcat容器,所以可以通過(guò)打包為jar包的方法將項(xiàng)目發(fā)布,但是如何將spring boot項(xiàng)目打包成可發(fā)布到tomcat中的war包項(xiàng)目呢?
網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)!專(zhuān)注于網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開(kāi)發(fā)、微信小程序定制開(kāi)發(fā)、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了鄠邑免費(fèi)建站歡迎大家使用!
1. 既然需要打包成war包項(xiàng)目,首先需要在pom.xml文件中修改打包類(lèi)型,將spring boot默認(rèn)的<packaging>jar</packaging>修改為<packaging>war</packaging>形式;
2. 其次spring boot的web項(xiàng)目中內(nèi)嵌tomcat服務(wù)器,所以如果我們想要發(fā)布war包到tomcat項(xiàng)目,要講spring boot中內(nèi)嵌的tomcat包依賴(lài)排除,不然產(chǎn)生沖突,打開(kāi)下面代碼中的注釋即可。
<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>
有一點(diǎn)想說(shuō)的是,如果本地開(kāi)發(fā)的時(shí)候依然想要使用spring boot內(nèi)嵌tomcat進(jìn)行調(diào)試,添加如下依賴(lài)即可;
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-tomcat</artifactId> <scope>provided</scope> </dependency>
3. spring boot發(fā)布jar包web程序的入口是main函數(shù)所在的類(lèi),使用@SpringBootApplication注解。但是如果war包發(fā)布至tomcat,需要增加 SpringBootServletInitializer 子類(lèi),并覆蓋它的 configure 方法,或者直接將main函數(shù)所在的類(lèi)繼承 SpringBootServletInitializer 子類(lèi),并覆蓋它的 configure 方法。代碼舉例如下,
@SpringBootApplication public class DemoApplication extends SpringBootServletInitializer { @Override protected SpringApplicationBuilder configure( SpringApplicationBuilder application) { return application.sources(DemoApplication.class); } public static void main(String[] args) { SpringApplication.run(DemoApplication.class, args); } }
以上就完成了spring boot項(xiàng)目打包war包的所有步驟,可以發(fā)布至tomcat7及其以上版本。
但是以上流程改造完spring boot打包war包發(fā)布至tomcat6版本之后,瀏覽器訪問(wèn)項(xiàng)目地址會(huì)給出404的錯(cuò)誤?為什么呢,一頭霧水,經(jīng)過(guò)我一番查閱資料以及實(shí)驗(yàn),得出以下結(jié)論,
首先spring boot支持的servlet容器如下,可以看出spring boot最低支持的servlet版本是3.0,但是tomcat6的servlet版本是2.5,這樣的話上面的流程是無(wú)法支持tomcat6發(fā)布spring boot項(xiàng)目的,
但是又google了一番,發(fā)現(xiàn)已經(jīng)有人在解決這個(gè)問(wèn)題了,https://github.com/dsyer/spring-boot-legacy,
標(biāo)題就表明了它是為了讓spring boot支持servlet2.5,剛好解決我們的痛點(diǎn),使用步驟如下:
1. pom.xml中添加spring-boot-legacy的依賴(lài),
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-legacy</artifactId> <version>1.1.0.RELEASE</version> </dependency>
2.手動(dòng)替換web.xml文件。但是在發(fā)布war包中發(fā)現(xiàn)metricFilter提示空指針異常,我就簡(jiǎn)單粗暴的將filter過(guò)濾了,注釋如下。 所要替換的web.xml文件的未知如下 : {工程目錄}/src/main/webapp/WEB-INF/web.xml
<?xml version="1.0" encoding="UTF-8"?> <web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"> <context-param> <param-name>contextConfigLocation</param-name> <param-value>com.example.DemoApplication</param-value> </context-param> <listener> <listener-class>org.springframework.boot.legacy.context.web.SpringBootContextLoaderListener</listener-class> </listener> <!-- <filter> <filter-name>metricFilter</filter-name> <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class> </filter> <filter-mapping> <filter-name>metricFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> --> <servlet> <servlet-name>appServlet</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> <param-name>contextAttribute</param-name> <param-value>org.springframework.web.context.WebApplicationContext.ROOT</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>appServlet</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> </web-app>
完成以上兩個(gè)步驟就可以讓spring boot項(xiàng)目支持tomcat6的部署了,解決。
思考:spring boot封裝帶來(lái)了便利性,同時(shí)也帶來(lái)了出問(wèn)題的解決復(fù)雜度,如果不了解原始的spring web開(kāi)發(fā)模式,出現(xiàn)問(wèn)題很難解決。即使我現(xiàn)在解決了支持tomcat6的spring boot支持問(wèn)題,但是不太明白解決的原理,filter出現(xiàn)空指針是為什么?所以深入一些原理性的東西,學(xué)習(xí)技術(shù)的基礎(chǔ)性的東西非常重要。大家可以明白的可以解釋解釋2.5支持的原理,以及filter空指針的異常原因。
PS:如何將Spring Boot項(xiàng)目打包部署到外部Tomcat
1.項(xiàng)目打包
項(xiàng)目開(kāi)發(fā)結(jié)束后,需要打包部署到外部服務(wù)器的Tomcat上,主要有幾種方式。
(1)生成jar包
cd 項(xiàng)目跟目錄(和pom.xml同級(jí)) mvn clean package ## 或者執(zhí)行下面的命令 ## 排除測(cè)試代碼后進(jìn)行打包 mvn clean package -Dmaven.test.skip=true
打包完成后jar包會(huì)生成到target目錄下,命名一般是 項(xiàng)目名+版本號(hào).jar
啟動(dòng)jar包命令
java -jar target/spring-boot-scheduler-1.0.0.jar
這種方式,只要控制臺(tái)關(guān)閉,服務(wù)就不能訪問(wèn)了。下面我們使用在后臺(tái)運(yùn)行的方式來(lái)啟動(dòng):
nohup java -jar target/spring-boot-scheduler-1.0.0.jar &
也可以在啟動(dòng)的時(shí)候選擇讀取不同的配置文件
java -jar app.jar --spring.profiles.active=product
也可以通過(guò)IDEA的Maven工具生成,點(diǎn)擊Lifecycle-install,生成jar
(2)生成war包
(1)修改打包類(lèi)型為war:<packaging>war</packaging>
<packaging>war</packaging>
(2)添加spring-boot-starter-tomcat依賴(lài),scope設(shè)置為provided
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-tomcat</artifactId> <scope>provided</scope> </dependency>
(3)注冊(cè)啟動(dòng)類(lèi)
創(chuàng)建ServletInitializer.java,繼承SpringBootServletInitializer ,覆蓋configure(),把啟動(dòng)類(lèi)Application注冊(cè)進(jìn)去。外部web應(yīng)用服務(wù)器構(gòu)建Web Application Context的時(shí)候,會(huì)把啟動(dòng)類(lèi)添加進(jìn)去。
public class ServletInitializer extends SpringBootServletInitializer { @Override protected SpringApplicationBuilder configure(SpringApplicationBuilder application) { return application.sources(BootdemoApplication.class); } }
同樣也是兩種方式執(zhí)行:
(1)mvn clean package -Dmaven.test.skip=true
(2)通過(guò)IDEA的Maven工具生成,點(diǎn)擊Lifecycle-package,生成war
2.項(xiàng)目部署
無(wú)論是用哪種方式生成,最終都是為了進(jìn)行部署,war可以直接拷到tomcat的webapps目錄下,啟動(dòng)Tomcat即可。
總結(jié)
以上所述是小編給大家介紹的把spring boot項(xiàng)目發(fā)布tomcat容器(包含發(fā)布到tomcat6的方法),希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)創(chuàng)新互聯(lián)網(wǎng)站的支持!
分享題目:把springboot項(xiàng)目發(fā)布tomcat容器(包含發(fā)布到tomcat6的方法)
轉(zhuǎn)載注明:http://www.rwnh.cn/article0/jjeooo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供ChatGPT、商城網(wǎng)站、小程序開(kāi)發(fā)、微信小程序、電子商務(wù)、用戶體驗(yàn)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)