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=/tmptomcat的baseDir,日志、dump等文件都存在于這個目錄中,一般是系統的臨時文件夾/tmp
,但也可以按照自己的需求變更位置。
server.tomcat.access-log-pattern= # log pattern of the access logserver.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@EnableAutoConfigurationpublic 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=profileUser=${your expected user}[Install]WantedBy=multi-user.targetSupervisord
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=profileuser=${your expected user}autostart=trueautorestart=truestartsecs=10startretries=3版權聲
新聞熱點
疑難解答