SpringBoot打成war包,部署到Tomcat服務器

原文鏈接:https://blog.csdn.net/qq_33512843/article/details/80951741

 

 SpringBoot默認達成jar包,使用SpringBoot構想web應用,默認使用內置的Tomcat。但考慮到項目需要集羣部署或者進行優化時,就需要打成war包部署到外部的Tomcat服務器中。

    本文所使用SpringBoot版本爲:2.0.3.RELEASE

一、修改pom.xml文件將默認的jar方式改爲war:


<groupId>com.example</groupId>
<artifactId>application</artifactId>
<version>0.0.1-SNAPSHOT</version>
<!--默認爲jar方式-->
<!--<packaging>jar</packaging>-->
<!--改爲war方式-->
<packaging>war</packaging>
二、排除內置的Tomcat容器(兩種方式都可):

1.排除spring-boot-starter-web中的Tomcat


<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>
2.添加依賴


<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-tomcat</artifactId>
    <!--打包的時候可以不用包進去,別的設施會提供。事實上該依賴理論上可以參與編譯,測試,運行等週期。
        相當於compile,但是打包階段做了exclude操作-->
    <scope>provided</scope>
</dependency>
三、繼承org.springframework.boot.web.servlet.support.SpringBootServletInitializer,實現configure方法:

爲什麼繼承該類,SpringBootServletInitializer源碼註釋:

Note that a WebApplicationInitializer is only needed if you are building a war file and deploying it. 

If you prefer to run an embedded web server then you won't need this at all.

注意,如果您正在構建WAR文件並部署它,則需要WebApplicationInitializer。

如果你喜歡運行一個嵌入式Web服務器,那麼你根本不需要這個。

啓動類代碼:

@SpringBootApplication
public class Application {

    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }

}
1.方式一,啓動類繼承SpringBootServletInitializer實現configure:
@SpringBootApplication
public class Application extends SpringBootServletInitializer {

    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }

    @Override
    protected SpringApplicationBuilder configure(SpringApplicationBuilder builder) {
        return builder.sources(Application.class);
    }
}
2.方式二,新增加一個類繼承SpringBootServletInitializer實現configure:

public class ServletInitializer extends SpringBootServletInitializer {

    @Override
    protected SpringApplicationBuilder configure(SpringApplicationBuilder builder) {
        //此處的Application.class爲帶有@SpringBootApplication註解的啓動類
        return builder.sources(Application.class);
    }

}
注意事項:

使用外部Tomcat部署訪問的時候,application.properties(或者application.yml)中配置的

server.port=

server.servlet.context-path=

將失效,請使用tomcat的端口,tomcat,webapps下項目名進行訪問。

爲了防止應用上下文所導致的項目訪問資源加載不到的問題,

建議pom.xml文件中<build></build>標籤下添加<finalName></finalName>標籤:

<build>
    <!-- 應與application.properties(或application.yml)中context-path保持一致 -->
    <finalName>war包名稱</finalName>
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
        </plugin>
    </plugins>
</build>
使用mvn命令行打包,運行:

clean是清除之前的包,-Dmaven.test.skip=true是忽略測試代碼

jar 方式打包,使用內置Tomcat:mvn clean install -Dmaven.test.skip=true

運行:java -jar 包名.jar

war方式打包,使用外置Tomcat:mvn clean package -Dmaven.test.skip=true

運行:${Tomcat_home}/bin/目錄下執行startup.bat(windows)或者startup.sh(linux)

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章