1. 程式人生 > >SpringBoot熱部署devtool和配置檔案自動注入(SpringBoot2.0系列-二)

SpringBoot熱部署devtool和配置檔案自動注入(SpringBoot2.0系列-二)

1、SpringBoot2.x使用Dev-tool熱部署

簡介:什麼是熱部署,使用springboot結合dev-tool工具,快速載入啟動應用

核心依賴包:

<dependency>  
         <groupId>org.springframework.boot</groupId>  
         <artifactId>spring-boot-devtools</artifactId>  
         <optional>true</optional>  
</dependency>

新增依賴後,在ide裡面重啟應用,後續修改後馬上可以生效

不被熱部署的檔案:

1、/META-INF/maven, /META-INF/resources, /resources, /static, /public, or /templates
2、指定檔案不進行熱部署 spring.devtools.restart.exclude=static/,public/
3、手工觸發重啟 spring.devtools.restart.trigger-file=trigger.txt
改程式碼不重啟,通過一個文字去控制
https://docs.spring.io/spring-boot/docs/2.1.0.BUILD-SNAPSHOT/reference/htmlsingle/#using-boot-devtools-restart-exclude

注意點:生產環境不要開啟這個功能,如果用java -jar啟動,springBoot是不會進行熱部署的

2、SpringBoot2.x配置檔案講解

簡介:SpringBoot2.x常見的配置檔案 xml、yml、properties的區別和使用
xml、properties、json、yaml

1、常見的配置檔案 xx.yml, xx.properties

1)YAML(Yet Another Markup Language)

a)寫 YAML 要比寫 XML 快得多(無需關注標籤或引號)
b)使用空格 Space 縮排表示分層,不同層次之間的縮排可以使用不同的空格數目
注意:key後面的冒號,後面一定要跟一個空格,樹狀結構

2)application.properties示例

  server.port=8090  
    server.session-timeout=30  
    server.tomcat.max-threads=0  
    server.tomcat.uri-encoding=UTF-8 

application.yml示例

server:  
        port: 8090  
        session-timeout: 30  
        tomcat.max-threads: 0  
        tomcat.uri-encoding: UTF-8 

2、預設示例檔案僅作為指導,不要將整個內容複製並貼上到應用程式中,只挑選需要的屬性。

如果需要修改,直接複製對應的配置檔案,加到application.properties裡面

3、SpringBoot註解把配置檔案自動對映到屬性和實體類

簡介:講解使用@value註解配置檔案自動對映到屬性和實體類

1、配置檔案載入

方式一:

1、Controller上面配置

@PropertySource({“classpath:resource.properties”})

2、增加屬性

@Value(“${test.name}”)\

private String name;

方式二:實體類配置檔案

步驟:

1、新增 @Component 註解;

2、使用 @PropertySource 註解指定配置檔案位置;

3、使用 @ConfigurationProperties 註解,設定相關屬性;

4、必須 通過注入IOC物件Resource 進來 , 才能在類中使用獲取的配置檔案值
@Autowired
private ServerSettings serverSettings;

例子:

  @Configuration
  @ConfigurationProperties(prefix="test")
  @PropertySource(value="classpath:resource.properties")
  public class ServerConstant {...}

常見問題:

1、配置檔案注入失敗,Could not resolve placeholder

解決:根據springboot啟動流程,會有自動掃描包沒有掃描到相關注解,
預設Spring框架實現會從宣告@ComponentScan所在的類的package進行掃描,來自動注入,
因此啟動類最好放在根路徑下面,或者指定掃描包範圍
spring-boot掃描啟動類對應的目錄和子目錄

2、注入bean的方式,屬性名稱和配置檔案裡面的key一一對應,就用加@Value 這個註解,
如果不一樣,就要加@value(“${XXX}”)