SpringBoot應用部署[轉]


在開發spring Boot應用的過程中,Spring Boot直接執行public static void main()函數並啟動一個內嵌的應用服務器(取決於類路徑上的以來是Tomcat還是jetty)來處理應用請求。對於生產環境,這樣的部署方式同樣有效,同時Spring Boot也支持傳統的部署方式——將war包放入應用服務器中啟動運行。

內嵌應用服務器

在使用Maven或Gradle構建Spring Boot應用的過程中,Spring Boot插件提供了巨大的幫助,除了生命各類預定義的依賴,它還能夠構建可以直接運行的jar包——包含了所有的依賴以及內嵌應用服務器。應用的分發也就變得非常簡單,任何人拿到了這個jar包,只需要簡單運行Java -jar your.jar就可以啟動應用,無需任何構建工具、安裝過程以及應用服務器。

內嵌應用服務器配置

在生產環境中,應用服務器需要各類配置,Spring Boot本身提供了一種非常簡單的配置機制——application.properties

server.port=8080 # 監聽端口 server.address= # 綁定的地址 server.session-timeout= #session有效時長 server.context-path= #默認為/ server.ssl.* #ssl相關配置

Tomcat

默認情況下,Spring Boot啟動的內嵌容器就是Tomcat,對於Tomcat有幾個非常重要的配置:

server.tomcat.basedir=/tmp

tomcat的baseDir,日志、dump等文件都存在於這個目錄中,一般是系統的臨時文件夾/tmp,但也可以按照自己的需求變更位置。

server.tomcat.access-log-pattern= # log pattern of the access log server.tomcat.access-log-enabled=false # is access logging enabled

這兩個配置打開Tomcat的Access日志,並可以設置日志格式。

Jetty

如果你不喜歡Tomcat,Jetty也是一個非常不錯的選擇。使用Jetty的方式也非常簡單——把tomcat依賴從Maven或Gradle中移除,加入Jetty內嵌容器的依賴:

<dependencies>  <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>  <dependency>  <groupId>org.springframework.boot</groupId>  <artifactId>spring-boot-starter-jetty</artifactId>  </dependency> <dependencies>

Java EE應用服務器

除了內嵌容器的部署模式,Spring Boot也支持將應用部署至已有的Tomcat容器, 或JBoss, WebLogic等傳統Java EE應用服務器。

以Maven為例,首先需要將<packaging>jar改成war,然后取消spring-boot-maven-plugin,然后修改Application.java

package demo; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.EnableAutoConfiguration; import org.springframework.boot.builder.SpringApplicationBuilder; import org.springframework.boot.context.web.SpringBootServletInitializer; import org.springframework.context.annotation.ComponentScan; import org.springframework.context.annotation.Configuration; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; @Configuration @ComponentScan @EnableAutoConfiguration public class Application extends SpringBootServletInitializer {  public static void main(String[] args) {  SpringApplication.run(applicationClass, args);  }  @Override  protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {  return application.sources(applicationClass);  }  private static Class<Application> applicationClass = Application.class; } 

接下來打包應用,將生成的war包放入應用服務器目錄即可。

使用外部配置文件

在應用程序中有很多配置項,例如數據庫連接地址、日志文件位置、應用服務器配置等等。為了安全與靈活性,我們推薦將Spring Boot的配置文件放在生產環境的服務器上,並嚴格控制訪問權限。在運行應用時可以通過命令行參數指定配置文件:

java -jar location_of_your_jar_file.jar --spring.config.location=location_of_your_config_file.properties

這樣做的好處是:

  • 配置位於生產環境中,數據庫連接等私密信息不容易泄露
  • 靈活性強,同一份代碼(包括構建的jar包)可以應用於不同的環境配置(開發、測試、生產)

使用Profile區分環境

在某些情況下,應用的某些業務邏輯可能需要有不同的實現。例如郵件服務,假設EmailService中包含的send(String email)方法向指定地址發送電子郵件,但是我們僅僅希望在生產環境中才執行真正發送郵件的代碼,而開發環境里則不發送以免向用戶發送無意義的垃圾郵件。

我們可以借助Spring的注解@Profile實現這樣的功能,這樣需要定義兩個實現EmailService借口的類:

@Service @Profile("dev") class DevEmailService implements EmailService {  public void send(String email) {  //Do Nothing  } } @Service @Profile("prod") class ProdEmailService implements EmailService {  public void send(String email) {  //Real Email Service Logic  } } 

@Profile("dev")表明只有Spring定義的Profile為dev時才會實例化DevEmailService這個類。那么如何設置Profile呢?

在配置文件中指定

application.properties中加入:

spring.profiles.active=dev

通過命令行參數

java -jar app.jar --spring.profiles.active=dev

以服務的形式運行應用

使用java命令運行應用非常簡單,但是通常我們都是通過ssh命令連接到服務器並運行它,一旦ssh連接斷開,那么由它fork的java子進程也就隨之銷毀了。所以我們必須借助工具將應用作為服務運行在服務器上:

Systemd

systemd 是Linux 下的一款系統和服務管理器。可以為Spring Boot應用編寫啟動腳本:

[Unit] Description=Spring Boot Application [Service] ExecStart=/usr/bin/java -jar location_of_jar_file.jar --spring.config.location=location_of_config.properties --spring.profiles.active=profile User=${your expected user} [Install] WantedBy=multi-user.target

Supervisord

Supervisord是用Python實現的一款非常實用的進程管理工具。可以為Spring Boot應用編寫:

[program:app] command=/usr/bin/java -jar location_of_jar_file.jar --spring.config.location=location_of_config.properties --spring.profiles.active=profile user=${your expected user} autostart=true autorestart=true startsecs=10 startretries=3


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM