SpringBoot打成war包,部署到Tomcat伺服器
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)