保姆教程系列三、Nacos Config--服務配置

来源:https://www.cnblogs.com/bgyb/archive/2022/03/31/16076797.html
-Advertisement-
Play Games

前言: 請各大網友尊重本人原創知識分享,謹記本人博客:南國以南i 上篇我們介紹到 保姆教程系列二、Nacos實現註冊中心 配置中心原理 一、 服務配置中心介紹 首先我們來看一下,微服務架構下關於配置文件的一些問題: 配置文件相對分散。在一個微服務架構下,配置文件會隨著微服務的增多變的越來越多,而且分 ...


前言:

請各大網友尊重本人原創知識分享,謹記本人博客:南國以南i

上篇我們介紹到  保姆教程系列二、Nacos實現註冊中心  

配置中心原理

 

一、 服務配置中心介紹

首先我們來看一下,微服務架構下關於配置文件的一些問題:

  1. 配置文件相對分散。在一個微服務架構下,配置文件會隨著微服務的增多變的越來越多,而且分散在各個微服務中,不好統一配置和管理。
  2. 配置文件無法區分環境。微服務項目可能會有多個環境,例如:測試環境、預發佈環境、生產環境。每一個環境所使用的配置理論上都是不同的,一旦需要修改,就需要我們去各個微服務下手動
    維護,這比較困難。
  3. 配置文件無法實時更新。我們修改了配置文件之後,必須重新啟動微服務才能使配置生效,這對一
    個正在運行的項目來說是非常不友好的。
    基於上面這些問題,我們就需要配置中心的加入來解決這些問題。

配置中心的思路是:

  • 首先把項目中各種配置全部都放到一個集中的地方進行統一管理,並提供一套標準的介面。
  • 當各個服務需要獲取配置的時候,就來配置中心的介面拉取自己的配置。
  • 當配置中心中的各種參數有更新的時候,也能通知到各個服務實時的過來同步最新的信息,使之動態更新。

當加入了服務配置中心之後,我們的系統架構圖會變成下麵這樣:

 在業界常見的服務配置中心,有下麵這些:

  • Apollo

Apollo是由攜程開源的分散式配置中心。特點有很多,比如:配置更新之後可以實時生效,支持灰度發佈功能,並且能對所有的配置進行版本管理、操作審計等功能,提供開放平臺API。並且資料也寫的很詳細。

  • Disconf

Disconf是由百度開源的分散式配置中心。它是基於Zookeeper來實現配置變更後實時通知和生效的。

  • SpringCloud Config

這是Spring Cloud中帶的配置中心組件。它和Spring是無縫集成,使用起來非常方便,並且它的配置存儲支持Git。不過它沒有可視化的操作界面,配置的生效也不是實時的,需要重啟或去刷新。

  • Nacos

這是SpingCloud alibaba技術棧中的一個組件,前面我們已經使用它做過服務註冊中心。其實它也集成了服務配置的功能,我們可以直接使用它作為服務配置中心。

二、Nacos Config入門

使用nacos作為配置中心,其實就是將nacos當做一個服務端,將各個微服務看成是客戶端,我們將各個微服務的配置文件統一存放在nacos上,然後各個微服務從nacos上拉取配置即可。

2.1 在父工程中在微服務中引入nacos的依賴

      <!--nacos配置中心依賴 推薦使用-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
            <version>2.1.1.RELEASE</version>
        </dependency>
        <!--nacos配置中心依賴-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
            <version>0.2.1.RELEASE</version>
        </dependency>

2.2 在微服務中添加nacos config的配置

註意:不能使用原來的application.yml作為配置文件,而是新建一個bootstrap.yml作為配置文件

配置文件優先順序(由高到低):
bootstrap.properties -> bootstrap.yml -> application.properties -> application.yml


 

#消費者配置
server:
  port: 8082

spring:
  application:
    name: nacos-consumer #服務名稱
  cloud:
    nacos:
      config: #使用配置中心
        enabled: true #配置全局開關 預設true開啟
        server-addr: 192.168.36.135:8848
        file-extension: yaml # 此處為配置使用的尾碼名
        prefix: nacos-consumer #DataId 名稱(預設就是服務名稱)
        group: DEFAULT_GROUP #分組名稱
      discovery:  #使用註冊中心
        server-addr: 192.168.36.135:8848 #服務地址
        enabled: true #是否開啟註冊 預設true開啟

  profiles:  
    active: dev  #讀取指定配置文件dev(開發環境),prod(生產環境),test(測試環境)

#開啟斷路器
feign:
 hystrix:
   enabled: true

#自定義屬性
test:
  name: "測試數據"

2.3  在nacos中添加配置

點擊配置列表,點擊右邊+號,新建配置。在新建配置過程中,要註意下麵的細節:
1)Data ID不能隨便寫,要跟配置文件中的對應,對應關係如圖所示
2)配置文件格式要跟配置文件的格式對應,且目前僅僅支持YAML和Properties
3)配置內容按照上面選定的格式書寫

註釋本地的application.yam中的內容, 啟動程式進行測試

如果依舊可以成功訪問程式,說明我們nacos的配置中心功能已經實現

 

三、Nacos Config深入

3.1 配置動態刷新

在入門案例中,我們實現了配置的遠程存放,但是此時如果修改了配置,我們的程式是無法讀取到的,因此,我們需要開啟配置的動態刷新功能。

3.2 獲取自定義屬性

方式一: 硬編碼方式

@RestController
public class NacosConfig {

    @Autowired
    private ConfigurableApplicationContext applicationContext;//獲取程式應用上下文


    /**
     * .
     * 硬編碼方式
     *
     * @return
     */
    @GetMapping("/nacos-config")
    public String nacosConfig() {
        return applicationContext.getEnvironment().getProperty("test.name");
    }

}

方式二: 註解方式(推薦)

@RefreshScope// 添加此註解表示會實時更新value 另外需要給屬性添加get set方法
@RestController
@Data
public class NacosConfig {


    /**
     * .
     * 獲取自定義屬性值
     */
    @Value("${test.name:default}")
    private String name;



    /**
     * .
     * 使用註解方式
     *
     * @return
     */
    @GetMapping("/config")
    public String config() {
        return name;
    }

四、配置共用

當配置越來越多的時候,我們就發現有很多配置是重覆的,這時候就可以考慮將公共配置文件提取出來,然後實現共用

4.1 新建一個名為nacos-common.yaml公共配置

只需要提取一個以nacos.common.yaml命名的配置文件,然後將其所有環境的公共配置放在裡面即可。

#公用配置
spring:
  cloud:
    nacos:
      discovery:  #使用註冊中心
        server-addr: 192.168.36.135:8848
        enabled: true #開啟註冊

4.2 修改providerconsumer中的bootstrap.yml

spring:
  application:
    name: nacos-consumer
  cloud:
    nacos:
      config: #使用配置中心
        enabled: true
        server-addr: 192.168.36.135:8848
        file-extension: yaml # 此處為配置使用的尾碼名
        prefix: nacos-consumer
        group: DEFAULT_GROUP  #分組名稱
        shared-dataids: nacos-common.yaml #配置引入公共配置
        refreshable-dataids: nacos-common.yaml # 配置要實現動態配置刷新的配置
#      discovery:  #使用註冊中心
#        server-addr: 192.168.36.135:8848
#        enabled: true

查看Nacos服務列表,發現服務依舊註冊成功,說明我們抽取公共配置功能已經實現

 五、基本概念

命名空間(Namespace)
命名空間可用於進行不同環境的配置隔離。一般一個環境劃分到一個命名空間
配置分組(Group)
配置分組用於將不同的服務可以歸類到同一分組。一般將一個項目的配置分到一組
配置集(Data ID)
在系統中,一個配置文件通常就是一個配置集。一般微服務的配置就是一個配置集

5.1 命名空間實例

如上述所說:一個環境劃分到一個命名空間,此處新建pro(生產環境命名空間)、dev(開發環境命名空間)

5.2 配置列表

在配置列表中可選多個命名空間:新建配置,即使Data ID 名稱重覆,也達到配置隔離的效果

5.3 使用樣例項目

修改consumer中的bootstrap.yml指定使用命名空間

spring:
  application:
    name: nacos-consumer #服務名稱
  cloud:
    nacos:
      config: #使用配置中心
        enabled: true #配置全局開關 預設true開啟
        server-addr: 172.16.18.176:8848
        file-extension: yaml # 配置文件格式
        prefix: nacos-consumer #DataId 名稱(預設就是服務名稱)
        group: DEFAULT_GROUP  #分組名稱
        shared-dataids: nacos-common.yaml #配置引入公共配置
        refreshable-dataids: nacos-common.yaml # 配置要實現動態配置刷新的配置
        namespace: 42910b90-d7f5-4342-b121-e0ebd429388f #命名空間ID(預設public)

上述指定讀取dev開發環境命名空間的配置文件(控制台輸出列印)

 

 修改上述namespace命名空間ID指定pro生產環境配置(控制台輸出列印)

 

 六、配置集遷移

6.1 配置集導出

勾選若幹配置集,點擊導出選中的配置,可獲得一個壓縮包

 

6.2 配置集導入

點擊右上角導入配置,可選擇導出的壓縮包文件,將壓縮包內的文件恢復為Nacos配置集

 

6.3 配置集克隆

點擊左下角克隆按鈕,將彈出克隆對話框,此功能可用於將配置遷移其它Namespace

 總結:

我是南國以南i記錄點滴每天成長一點點,學習是永無止境的!轉載請附原文鏈接!!!

參考鏈接


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

-Advertisement-
Play Games
更多相關文章
  • 前言 首先描述下業務場景,有一個介面,其中存在耗時操作,耗時操作的執行結果將寫入數據表中,不需要通過該介面直接返回。 因此理論上該介面可以在耗時操作執行結束前返回。本文中使用多線程後臺運行耗時操作,主線程提前返回,實現介面的提前返回。 此外,還嘗試使用協程實現,經驗證,協程適用於多任務併發處理,遇到 ...
  • 簡介 Apollo(阿波羅)是攜程框架部門研發的分散式配置中心,能夠集中化管理應用不同環境、不同集群的配置,配置修改後能夠實時推送到應用端,並且具備規範的許可權、流程治理等特性,適用於微服務配置管理場景。 服務端基於Spring Boot和Spring Cloud開發,打包後可以直接運行,不需要額外安 ...
  • 一、前言 眾所周知,Python 不是一種執行效率較高的語言。此外在任何語言中,迴圈都是一種非常消耗時間的操作。假如任意一種簡單的單步操作耗費的時間為 1 個單位,將此操作重覆執行上萬次,最終耗費的時間也將增長上萬倍。 while 和 for 是 Python 中常用的兩種實現迴圈的關鍵字,它們的運 ...
  • 前言 本片博客記錄快速創建springboot工程的兩種方式。一種是使用maven創建,一種是使用spring initializr創建。開發環境JDK1.8、IDEA、maven。 SpringBoot 優點 可快速構建spring應用 直接嵌入tomcat、jetty、undenrtow伺服器( ...
  • 大家好,我是棧長。 相信大家看到了昨天的 Spring 漏洞,嚴重級別僅為中等,不必慌張, 棧長沒想到的是,自這個月初 Spring Cloud Gateway 突發高危漏洞,現在 Spring Cloud 另外一個 Spring Cloud Function 模塊也淪陷了。。。 來看最新昨天 Sp ...
  • springboot微服務整合swagger3方法很簡單,下文會演示。但是在分散式項目中如果每個微服務都需要單獨的分開訪問獲取介面文檔就不方便了,本文將詳細講解springcloud gateway網關如何聚合統一管理swagger介面文檔。 先貼張整合後的效果圖(通過切換左上角的下拉視窗獲取每個微 ...
  • 如何才能寫好Python代碼?很多小伙伴都會問這樣的問題,今天這篇就來告訴大家怎樣寫好Python代碼。 程式設計的好與壞,早在我們青蔥歲月時就接觸過了,只是那是並不知道這竟如此重要。能夠立即改善程式設計、寫出“好”代碼的知識有以下幾點: •面向對象五個基本原則; •常見的三種架構; •繪圖; •起 ...
  • 大家好,我是棧長。 最近技術棧真是醉了,Log4j2 的核彈級漏洞剛告一段落,這個月初 Spring Cloud Gateway 又突發高危漏洞,現在連最要命的 Spring 框架也淪陷了。。。 棧長今天看到了一些安全機構發佈的相關漏洞通告,Spring 官方博客也發佈了漏洞聲明: 漏洞描述: 用戶 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...