部署Spring-boot

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
    <packaging>war</packaging>
    
    這樣就能生成WAR文件了。但如果WAR文件里沒有啟用Spring MVC DispatcherServletweb.xml 文件或者Servlet初始化類,這個(gè)WAR文件就一無是處。
    Spring Boot提供的 SpringBootServletInitializer 是一個(gè)支持
    Spring Boot的 Spring WebApplicationInitializer 實(shí) 現(xiàn) 。除了 配置 Spring 的 Dispatcher-Servlet , SpringBootServletInitializer 還會(huì)在Spring應(yīng)用程序上下文里查找 FilterServletServletContextInitializer類型的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到tomcatwebapps 目錄

  • 不用重啟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)物就能有兩種部署方式了!

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容