SpringBoot應(yīng)用程序有多種構(gòu)建和運(yùn)行方式(開發(fā)環(huán)境)
- 在IDE中運(yùn)行應(yīng)用程序(涉及Spring ToolSuite或IntelliJ IDEA)
- 使用Maven的 spring-boot:run 或Gradle的 bootRun ,在命令行里運(yùn)行。
- 使用Maven或Gradle生成可運(yùn)行的JAR文件,隨后在命令行中運(yùn)行
- 使用Spring Boot CLI在命令行中運(yùn)行Groovy腳本
- 使用Spring Boot CLI來生成可運(yùn)行的JAR文件,隨后在命令行中運(yùn)行
部署到生產(chǎn)環(huán)境
- 修改pom.xml, 將
jar改為war
這樣就能生成WAR文件了。但如果WAR文件里沒有啟用Spring MVC<packaging>war</packaging>DispatcherServlet的web.xml文件或者Servlet初始化類,這個(gè)WAR文件就一無是處。
Spring Boot提供的SpringBootServletInitializer是一個(gè)支持
Spring Boot的Spring WebApplicationInitializer實(shí) 現(xiàn) 。除了 配置 Spring 的Dispatcher-Servlet,SpringBootServletInitializer還會(huì)在Spring應(yīng)用程序上下文里查找Filter、Servlet或ServletContextInitializer類型的Bean,把它們綁定到Servlet容器里.
要使用SpringBootServletInitializer,只需創(chuàng)建一個(gè)子類,覆蓋 configure() 方法來指定Spring配置類
注意: pom.xml中的加載的jdk版本是:
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
</properties>
- 修改Spring Boot啟動(dòng)類, 讓其繼承
SpringBootServletInitializer并重寫configure方法如下:
package com.example.readinglist;
import groovy.lang.Grab;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.builder.SpringApplicationBuilder;
import org.springframework.boot.web.support.SpringBootServletInitializer;
/**
* Spring Boot 啟動(dòng)類
*/
@SpringBootApplication
//@Grab("spring-boot-starter-remote-shell")
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);
}
}
-
命令行下到項(xiàng)目的根目錄, 打包
cd /home/lxf/test/readinglist/ //-Dmaven.test.skip=true代表跳過單元測(cè)試 mvn package -Dmaven.test.skip=true成功后會(huì)在 /home/lxf/test/readinglist/target/目錄生成
readinglist-0.0.1-SNAPSHOT.war包 將生成的war包c(diǎn)opy到
tomcat的webapps目錄不用重啟tomcat, 直接訪問:http://localhost:8081/readinglist-0.0.1-SNAPSHOT/hello
readinglist-0.0.1-SNAPSHOT.war可以自行修改為任意文件名, 比如: 修改為readinglist.war, 那么訪問的路徑就是: http://localhost:8081/hello
注意: 以上8081端口是我tomcat配置的端口,并不是在application.yml配置的服務(wù)端口, application.yml中配置的端口是為了Spring Boot內(nèi)嵌tomcat配置的,與打包后部署到tomcat并無任何關(guān)系;-
訪問后會(huì)自動(dòng)解壓war包, 解壓后的內(nèi)容如下:
image.png
其中org目錄下是Spring Boot相關(guān)文件
-
訪問會(huì)出現(xiàn)404, 是因?yàn)槲业膖omcat配置的是加載
jdk-1.7版本, 而Spring Boot配置的是1.8, 所以要修改tomcat對(duì)應(yīng)的 jdk 版本:
在/usr/local/tomcat/bin/catalina.sh和/usr/local/tomcat/bin/setclasspath.sh兩個(gè)文件起始部分填入JAVA_HOME=/usr/lib/jvm/jdk1.8.0_131 JRE_HOME=/usr/lib/jvm/jdk1.8.0_131/jre重啟tomcat即可, 在重啟的時(shí)候會(huì)看到tomcat加載jdk的版本:
image.png -
還有一點(diǎn)值得注意
我們?cè)跇?gòu)建的是WAR文件,這個(gè)文件仍舊可以脫離應(yīng)用服務(wù)器直
接運(yùn)行。如果你沒有刪除DemoApplication里的main()方法,構(gòu)建過程生成的WAR文件仍可直接運(yùn)行,一如可執(zhí)行的JAR文件:$ java -jar readinglist-0.0.1-SNAPSHOT.war這樣一來,同一個(gè)部署產(chǎn)物就能有兩種部署方式了!

