Spring Boot 配置文件總結

来源:https://www.cnblogs.com/god23bin/archive/2023/05/14/spring-boot-configuration-file.html
-Advertisement-
Play Games

1. 配置文件的兩種寫法:properties 和 yml 2. 項目中存在多個配置文件,可以使用 spring.profiles.active 屬性來切換使用哪個配置文件。 3. 自定義的一些配置屬性(配置項),如何讀取呢?可以在程式中通過 @Value 或者 @ConfigurationPr... ...


前言

Spring Boot 中提供一個全局的配置文件:application.properties,這個配置文件的作用就是,允許我們通過這個配置文件去修改 Spring Boot 自動配置的預設值

Spring Boot 支持兩種格式的配置文件:application.propertiesapplication.yml

yml 等同於 yaml,寫法看個人喜歡,我喜歡寫成 application.yml

不同尾碼不同寫法

application.propertiesapplication.yml ,它們的區別在於語法不同,但本質上是一樣的。application.properties 使用鍵值對的方式來配置,而 application.yml 使用縮進和冒號的方式來配置。

properties

properties 作為尾碼的配置文件,語法是這樣的:key = value,如果有多級配置項,則是 first.second.third = value

key=value
first.second.third=value

示例:

  1. 定義屬性:
key=value
game.name=GTA5

這裡的 keygame.name 都是屬性名稱,而 valueGTA5 是屬性的

  1. 定義 List:
game.list=GTA5,NBA2K,AC

這裡的 game.list 這個列表包含了 3 個元素。

  1. 定義 Map:
game.map.key1=value1
game.map.key2=value2

這裡的 game.map 是一個 Map,這個 Map 包含了兩個元素,key1 映射到 value1,key2 映射到 value2

  1. 引用已定義的屬性:
game.name=GTA5
# 引用上面已定義的屬性
great.game=${game.name}

yml (yaml)

yml 作為尾碼的配置文件,語法是這樣的:key: value。使用冒號代替等號,同時冒號後面需要跟上一個空格符,不可省略。

key: value
first:
  second:
    third: value

示例:

  1. 定義屬性:
key: value
game:
  name: GTA5
  1. 定義 List:
game:
  list:
    - GTA5
    - NBA2K
    - AC
  1. 定義 Map:
game:
  map:
    key1: value1
    key2: value2
  1. 引用已定義的屬性:
game:
  name: GTA5
great:
  game: @{game.name}

不同環境下切換不同的配置文件

一般項目中在不同環境下都有不同的配置,還是以這個 Tomcat 的埠號為例:

目前有 3 個環境,分別是開發環境、測試環境、生產環境。在開發環境下,埠號是 4790;測試環境下,埠號是 4791;生產環境下是 4792。

application-dev.yml

server:
  port: 4790

application-test.yml

server:
  port: 4791

application-prod.yml

server:
  port: 4792

spring.profiles.active

現在,通過 spring.profiles.active 這個配置項,在 application.yml 中指定我們想要切換的配置文件,現在指定使用開發環境的配置文件

# 指定使用 application-dev.yml 這個配置文件
spring:
  profiles:
    active: dev

啟動 Spring Boot 應用,控制台輸出:

2023-03-16 15:41:48.122  INFO 3356 --- [           main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat started on port(s): 4790 (http) with context path ''

指定使用測試環境下的配置文件

# 指定使用 application-test.yml 這個配置文件
spring:
  profiles:
    active: test

啟動 Spring Boot 應用,控制台輸出:

2023-03-16 15:42:21.462  INFO 24548 --- [           main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat started on port(s): 4791 (http) with context path ''

同理,指定使用生產環境的配置文件也是一樣的做法。

自定義的配置

在 Spring Boot 項目中,自定義配置是經常用到的,我目前體會到的自定義的配置的作用有一點:配置與代碼解耦

下麵,我們看看如何自定義配置,並使用自己自定義配置的值:

server:
  port: 4790

# 自定義的配置
demo:
  author: god23bin
  description: 點個免費的贊,我能開心好久!

上面自定義了兩個配置項,分別是 demo.authordemo.description,接著,如何在代碼中使用這些配置好的值呢?

目前使用這些配置好的值(讀取這些值),有以下幾種方式:

  • 使用 @Value
  • 使用 @ConfigurationProperties

@Value

我們寫一個普通的 Java 類,使用 Spring 提供的 @Value 來讀取這兩個值:

@Data
@Component
public class DemoCustomConfig {

    /**
     * 通過 @Value 註解讀取配置文件中的自定義配置項的值,使用 ${} 進行讀取
     **/
    @Value("${demo.author}")
    private String author;

    @Value("${demo.description}")
    private String description;

}

上面的代碼中,我在類上使用了 @Data@Component@Data 是來自 Lombok 的,用於生成 getter 和 setter 方法,@Component 則將該類的實例對象交給 Spring 管理,接著在該類的兩個屬性上分別使用了 @Value 註解,通過 ${} 指定了我們要讀取的配置項。

進行測試,我們寫一個 Controller 判斷我們的讀取是否成功:

@RequestMapping("/demo")
@RestController
public class DemoController {

    @Autowired
    private DemoCustomConfig demoCustomConfig;

    @GetMapping("/getCustomValue")
    public ResponseEntity<String> getCustomValue() {
        return ResponseEntity.ok(demoCustomConfig.getAuthor() + "說:" + demoCustomConfig.getDescription());
    }
}

訪問該介面:localhost:4790/demo/getCustomValue

image-20230321233256647

@ConfigurationProperties

@ConfigurationProperties 註解,它可以將配置文件中的的值綁定到 Java Bean 中,也就是通過這個 Bean 可以讀取到配置文件中配置的值,我們看看如何操作。

我們自定義一個用於讀取配置文件中配置項的類:

@Data
@Component
@ConfigurationProperties("system.demo")
public class SystemCustomConfig {

    private String name;

    private String version;

}

上面的代碼,主要使用了 @ConfigurationProperties 這個註解,並指定了首碼 system.demo,同時這個類有兩個屬性,name 和 version, 這樣就相當於我們自定義了 system.demo.namesystem.demo.version 這兩個屬性。

接著,我們就能在配置文件中寫這兩個我們自定義的配置項了:

server:
  port: 4790

# 自定義的配置
system:
  demo:
    name: 超級系統
    version: 1.0

寫完這裡的配置項,並不需要使用 @Value 去讀取,因為使用了 @ConfigurationProperties 註解,Spring 已經幫我們搞定了配置的值的讀取,至於它的實現原理,這裡先不深究。

進行測試,依然通過寫一個介面來測試我們通過:

@RequestMapping("/demo")
@RestController
public class DemoController {

    @Autowired
    private SystemCustomConfig systemCustomConfig;

    @GetMapping("/getSystemVersion")
    public ResponseEntity<String> getSystemVersion() {
        return ResponseEntity.ok(systemCustomConfig.getName() + "版本:" + systemCustomConfig.getVersion());
    }
}

訪問該介面:localhost:4790/demo/getSystemVersion

image-20230321233317428

關於自動提示

不過,目前有個問題就是,我們自己寫了個 Java Bean 後,在配置文件中寫配置項的時候並沒有相關提示,這個就比較不友好,如果當我們自己寫的配置想要給其他人用的話,別人都不知道有什麼配置可以配。所以想要能像 Spring Boot 提供的配置提示一樣的話,就需要引入下麵的依賴:

<!-- 配置文件處理器,配置文件進行綁定就會有提示 -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-configuration-processor</artifactId>
    <optional>true</optional>
</dependency>

spring-boot-configuration-processor 是一個用於生成配置元數據的註解處理器。它會掃描使用 @ConfigurationProperties 註解的類和方法,來獲取配置參數並生成配置元數據。生成的配置元數據可以用於 IDE 的自動補全和提示功能。

image-20230322233941391

如果你引入了這個依賴並且重啟該 Spring Boot 項目後,依舊沒有提示的話,嘗試開啟 IDEA 中的 annotaion processing

image-20230322234341016

關於 Cannot resolve configuration property

對於我們自定義的配置,會出現這樣的提示:Cannot resolve configuration property(無法處理自定義的配置屬性),如下:

image-20230322235035717

解決方式就是定義一下元數據,用元數據來描述這個屬性。當我們移動到這個配置項上時,出現提示,我們直接點擊 Define configuration key xxx 就可以幫我們生成一個關於配置的元數據文件。

additional-spring-configuration-metadata.json

{
  "properties": [
    {
      "name": "demo.author",
      "type": "java.lang.String",
      "description": "Demo的作者"
    },
    {
      "name": "demo.description",
      "type": "java.lang.String",
      "description": "Demo的描述"
    }
  ]
}

此時,還是一樣,重啟項目,如果黃色提示還是沒有去除的話,這裡建議重新用 Maven 進行一次 clean,接著重新編譯整個項目,就可以了。於此同時,也具有了自動提示功能。

image-20230322235958525

自定義配置文件

上面說的是自定義的配置,現在這裡說自定義的配置文件,我們知道 Spring Boot 預設提供 application.properties 這個配置文件。那現在我們想自己寫一個配置文件,並且能在應用中讀取這個配置文件的信息,該如何做呢?這裡就涉及到 @PropertySource 這個註解了。

自定義的配置文件:

custom.yml

# 自定義的配置文件
version: 2.0
description: 求關註!

讀取該配置文件的配置類:

@Data
@Configuration
@PropertySource("classpath:custom.yml")
public class DemoPropertiesSourceConfig {

    @Value("${version}")
    private String version;

    @Value("${description}")
    private String description;

}

這樣,就能讀取到自己編寫的配置文件的配置信息了。

如果有多個自定義的配置文件,那麼可以使用 @PropertySources 註解,可以看到最後面多加了一個 s ,說明這個單詞是複數,通俗易懂。

@Configuration
@PropertySources({
    @PropertySource("classpath:custom1.yml"),
    @PropertySource("classpath:custom2.properties")
})
public class MyConfig {
    // ...
}

總結

  1. 配置文件的兩種寫法:properties 和 yml

  2. 項目中存在多個配置文件,可以使用 spring.profiles.active 屬性來切換使用哪個配置文件。

  3. 自定義的一些配置屬性(配置項),如何讀取呢?可以在程式中通過 @Value 或者@ConfigurationProperties 來讀取。

  4. 自定義的配置文件,可以通過 @PropertySource 來指定獲取該自定義配置文件的信息。

最後的最後

希望各位屏幕前的靚仔靚女們給個三連!你輕輕地點了個贊,那將在我的心裡世界增添一顆明亮而耀眼的星!

咱們下期再見!


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • mysql之數據操作 第一章 添加數據 通常向表中添加數據應該包含表中的所有欄位,即為表中所有欄位添加數據。但也可不包含所有欄位來添加數據 1.1、所有欄位 按照所有欄位來添加數據,有兩種方式: 語法1: insert into 表名(所有欄位) values(欄位對應的值); 語法2: inser ...
  • 2023-05-14 記錄一下今天學習的內容 (1)今天看了在vscode中將代碼提交到Gitee中。使用的方法如下: ①使用PowerShell打開終端(使用cmd也可以),之後打開你項目所在的文件,使用命令 git init 初始化一個倉庫 ②之後將代碼提交到暫存區中,使用的命令是 git ad ...
  • 開始 mock一個用於攔截ajax請求,並返回模擬數據的庫。主要讓前端獨立於後端進行開發,通過 pnpm add mockjs 來進行安裝 基礎 初窺門徑 var data = Mock.mock({ // 屬性 list 的值是一個數組,其中含有 1 到 10 個元素 'list|1-10': [ ...
  • 架構圖一詞應用比較廣泛,涉及到各個行業,從軟硬體領域來對架構圖分類就有如下幾種 物理架構 描述整個信息系統需要使用到的軟硬體設施,以及其部署位置及各個軟硬體之間的關聯關係。軟硬體設施包括主機、伺服器、交換機、路由器、防火牆、緩存伺服器、註冊中心、資料庫等等。 如下兩種架構圖屬於物理架構: 部署圖 基 ...
  • 0 文章概述 大家想一想工作中有沒有遇到以下情況:一位同事用了很長時間羅列了很多事實和數據向你說明一件事情,但是你聽完根本不知道他想要說什麼。一位同事用了大量筆墨編寫了技術方案,不僅有文字還有圖表,但是你看完也不知道這個方案到底要解決什麼問題以及如何落地。 上述情況的出現大概率是因為表述者沒有使用結 ...
  • DDD作為架構設計思想幫助微服務控制規模複雜度,那它是怎麼做到的呢? 一、架構設計是為瞭解決系統複雜度 談到架構,相信每個技術人員都是耳熟能詳,但如果深入探討一下,“為何要做架構設計?”或者“架構設計目的是什麼?”類似的問題,大部分人可能從來沒有思考過,或者即使有思考,也沒有太明確可信的答案。 1. ...
  • 本文主要講解了京東百億級商品車型適配數據存儲結構設計以及怎樣實現適配介面的高性能查詢。通過京東百億級數據緩存架構設計實踐案例,簡單剖析了jimdb的點陣圖(bitmap)函數和lua腳本應用在高性能場景。希望通過本文,讀者可以對緩存的內部結構知識有一定瞭解,並且能夠以最小的記憶體使用代價將點陣圖(bitm... ...
  • requires 是 C++20 中引入的一個新關鍵字,用於在函數模板或類模板中聲明所需的一組語義要求,它可以用來限制模板參數,類似於 typename 和 class 關鍵字。 requires關鍵字常與type_traits頭文件下類型檢查函數匹配使用,當requires後的表達式值為true時 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...