學習Spring Boot:(三)配置文件


前言

Spring Boot使用習慣優於配置(項目中存在大量的配置,此外還內置了一個習慣性的配置,讓你無需手動進行配置)的理念讓你的項目快速運行起來。

正文

使用配置文件注入屬性

Spring Boot 默認的配置文件src/main/java/resources/application.properties或者src/main/java/resources/application.yml,在這里我們可以配置一些常量。
首先我們使用配置文件給一個類注入相關的屬性:

com.wuwii.controller.pet.no=${random.uuid}
com.wuwii.controller.pet.name=Tom

通過注解@Value(value=”${config.name}”)就可以綁定到你想要的屬性上面。

@RestController
@RequestMapping("/pet")
public class PetController {
    @Value("${com.wuwii.controller.pet.no}")
    private String no;
    @Value("${com.wuwii.controller.pet.name}")
    private String name;
    @RequestMapping("/d")
    public String detail() {
        return "no: " + no + ", name: " + name;
    }

}

啟動

一個個綁定數據還是很不方便,可以新建一個Bean,專門用來綁定注入的屬性使用注解@ConfigurationProperties(prefix = “prefix”),不過需要注意的是先要引入相關依賴

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

通過使用spring-boot-configuration-processor jar, 你可以從被@ConfigurationProperties注解的節點輕松的產生自己的配置元數據文件。

這里我新建一個PetBean用來注入屬性。

@ConfigurationProperties(prefix = "com.wuwii.controller.pet")
public class PetBean {
    private String no;
    private String name;

    public String getNo() {
        return no;
    }

    public void setNo(String no) {
        this.no = no;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

注意在啟動類上加上注解

@EnableConfigurationProperties({PetBean.class}),

根據字面意思不難理解,就是開啟配置屬性。

新建一個controller,注入我們創建的PetBean,

@RestController
@RequestMapping("/v2/pet")
public class PetController1 {
    @Autowired
    private PetBean pet;
    @RequestMapping("/d")
    public String detail() {
        return "no: " + pet.getNo() + ", name: " + pet.getName();
    }
}

重啟Spring Boot,訪問新地址:

使用自定義的配置文件

我們在resouce目錄下面創建一個bean/pet.properties,加入

com.wuwii.name=Tom
com.wuwii.no=123456

新建一個PetBean1.java:
@PropertySource 這個注解可以指定具體的屬性配置文件,優先級比較低。

@Configuration
@ConfigurationProperties(prefix = "com.wuwii")
@PropertySource("classpath:bean/pet.properties")
public class PetBean1 {
    private String no;
    private String name;

    public String getNo() {
        return no;
    }

    public void setNo(String no) {
        this.no = no;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

在controller中加入PetBean1的注入

@Autowired
    private PetBean1 pet1;
    @RequestMapping("/d2")
    public String detail2() {
        return "no: " + pet1.getNo() + ", name: " + pet1.getName();
    }

應用配置文件(.properties或.yml)

在配置文件中直接寫:

server.port=8080

.yml格式的配置文件如:

server:
    port: 8080

tips: .yml中冒號后面一定要加一個空格。

隨機數

配置文件中${random} 可以用來生成各種不同類型的隨機值,

my.secret=${random.value}
my.number=${random.int}
my.bignumber=${random.long}
my.number.less.than.ten=${random.int(10)}
my.number.in.range=${random.int[1024,65536]}

屬性占位符

app.name=MyApp
app.description=${app.name} is a Spring Boot application

可以在配置文件中引用前面配置過的屬性(優先級前面配置過的這里都能用)。
通過如${app.name:默認名稱}方法還可以設置默認值,當找不到引用的屬性時,會使用默認的屬性。

屬性名匹配規則

例如有如下配置對象:

@Component
@ConfigurationProperties(prefix="person")
public class ConnectionSettings {

    private String firstName;

}

firstName可以使用的屬性名如下:
* person.firstName,標准的駝峰式命名
* person.first-name,虛線(-)分割方式,推薦在.properties和.yml配置文件中使用
* PERSON_FIRST_NAME,大寫下划線形式,建議在系統環境變量中使用

屬性驗證

可以使用JSR-303注解進行驗證,例如:

@Component
@ConfigurationProperties(prefix="connection")
public class ConnectionSettings {

    @NotNull
    private InetAddress remoteAddress;

    // ... getters and setters

}

配置文件的優先級

Spring Boot 支持多種外部配置方式,這些方式優先級如下:
1. 命令行參數
2. 來自java:comp/env的JNDI屬性
3. Java系統屬性(System.getProperties()
4. 操作系統環境變量
5. RandomValuePropertySource配置的random.*屬性值
6. jar包外部的application-{profile}.propertiesapplication.yml(帶spring.profile)配置文件
7. jar包內部的application-{profile}.propertiesapplication.yml(帶spring.profile)配置文件
8. jar包外部的application.propertiesapplication.yml(不帶spring.profile)配置文件
9. jar包內部的application.propertiesapplication.yml(不帶spring.profile)配置文件
10. @Configuration注解類上的@PropertySource
11. 通過SpringApplication.setDefaultProperties指定的默認屬性

同樣,這個列表按照優先級排序,也就是說,src/main/resources/config下application.properties覆蓋src/main/resources下application.properties中相同的屬性,此外,如果你在相同優先級位置同時有application.properties和application.yml,那么application.properties里的屬性里面的屬性就會覆蓋application.yml。

Profile-多環境配置

當應用程序需要部署到不同運行環境時,一些配置細節通常會有所不同,最簡單的比如日志,生產日志會將日志級別設置為WARN或更高級別,並將日志寫入日志文件,而開發的時候需要日志級別為DEBUG,日志輸出到控制台即可。
如果按照以前的做法,就是每次發布的時候替換掉配置文件,這樣太麻煩了,Spring Boot的Profile就給我們提供了解決方案,命令帶上參數就搞定。

這里我們來模擬一下,只是簡單的修改端口來測試
在Spring Boot中多環境配置文件名需要滿足application-{profile}.properties的格式,其中{profile}對應你的環境標識,比如:

  • application-dev.properties:開發環境
  • application-prod.properties:生產環境

然后在application.properties中加入

spring.profiles.active=dev

或application.yml中加入

spring:
    # 環境 dev|test|pro
    profiles:
        active: dev

或啟動命令:

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

參數用–xxx=xxx的形式傳遞。意思就是表示在application.properties文件中配置了屬性。
可以通過SpringApplication.setAddCommandLineProperties(false)禁用命令行配置。

附:Appendix A. Common application properties

Appendix A. Common application properties

參考文章


免責聲明!

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



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