亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Nacos配置文件使用經(jīng)驗及CAP原則詳解

 更新時間:2024年02月16日 10:30:27   作者:KerryWu  
這篇文章主要為大家介紹了Nacos配置文件使用經(jīng)驗及CAP規(guī)則詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

1、入門

發(fā)布配置

Data ID: nacos‐simple‐demo.yaml

Group : DEFAULT_GROUP

配置格式: YAML

配置內(nèi)容: common:

     ;                   config1: something

新建配置

在spring cloud生態(tài)下使用nacos config很容易,引入pom依賴:

<dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>

創(chuàng)建bootstrap.properties文件,并添加nacos server的連接地址即可:

spring.application.name=demo-api
spring.cloud.nacos.config.server-addr=nacos服務器地址
spring.cloud.nacos.config.prefix=nacos匹配配置前綴,默認為${spring.application.name}

2、配置文件

2.1. 規(guī)則配置

nacos上的dataId完整格式如下:

${prefix}-${spring.profile.active}.${file-extension}
  • prefix:取自bootstrap配置文件里面spring.cloud.nacos.config.prefix的值,而該配置的默認值又為${spring.application.name}
  • spring.profile.active:取當前環(huán)境的profile。如果項目spring.profile.active為空,dataId格式變成 ${prefix}.${file-extension}
  • file-exetension:為配置內(nèi)容的數(shù)據(jù)格式,可以通過配置項 spring.cloud.nacos.config.file-extension來配置。目前只支持 properties和yaml類型,默認properties。

實際測試,如果配置了spring.profile.active,項目會主動獲取nacos服務器上的配置文件包括:

${prefix}-${spring.profile.active}.${file-extension}

${prefix}.${file-extension}

2.2. 共享配置

大一點的項目,通常需要將配置信息拆分成多個配置文件,如:數(shù)據(jù)庫連接信息、多語言配置等。因此就存在了兩種情況:

  • 一個項目會加載多個配置文件。
  • 多個項目會共享同一個配置文件。

此時可以使用 shared-configs 或 extension-configs ,一直沒發(fā)現(xiàn)二者之間有啥區(qū)別,作用和用法基本一樣。例如:

spring.cloud.nacos.config.shared-configs[0].data-id=mysql.properties
spring.cloud.nacos.config.shared-configs[0].group=DATABASE_GROUP
spring.cloud.nacos.config.shared-configs[1].data-id=redis.properties
spring.cloud.nacos.config.shared-configs[1].group=DATABASE_GROUP
spring.cloud.nacos.config.shared-configs[2].data-id=common-i18n.properties
spring.cloud.nacos.config.shared-configs[2].group=I18N_GROUP
spring.cloud.nacos.config.shared-configs[2].refresh=true

上述配置中,將 shared-configs[n] 替換成 extension-configs[n],并沒有任何不同。

3. 優(yōu)先級

1.配置文件優(yōu)先級

按照前面介紹的,在使用nacos后,項目的配置文件來源多了起來,按照從高到低的優(yōu)先級順序分別為:

  • 通過內(nèi)部相關規(guī)則 ${prefix}-${spring.profile.active}.${file-extension} 自動生成相關的Data Id配置。
  • 通過 extension-configs 方式支持的Data Id配置。
  • 通過 shared-configs 方式支持的Data Id配置。

2. 共享配置內(nèi)部優(yōu)先級

共享配置 shared-configs[n]、extension-configs[n]內(nèi)部,n的值越大,優(yōu)先級越高。

前面的例子中優(yōu)先級順序:common-i18n.properties > redis.properties > mysql.properties

3. 本地優(yōu)先級

如果在配置文件中開啟了nacos config,在nacos服務器和項目本地,都創(chuàng)建了同樣的配置文件。nacos服務器上的配置項,優(yōu)先級比本地高。

4. 通過日志查看優(yōu)先級

當你實在搞不清naco配置文件加載的優(yōu)先級時,不要慌,直接看啟動項目日志即可。

在spring項目中開啟nacos config后,啟動項目會在控制臺打印出nacos加載的所有配置文件,而且按照優(yōu)先級順序從前往后排序。

如按照前面的配置,打印出來的日志為:

[PropertySourceBootstrapConfiguration.java:112] [] [ ] - Located property source: [BootstrapPropertySource {name='bootstrapProperties-demo-api-native.properties,DEFAULT_GROUP'}, BootstrapPropertySource {name='bootstrapProperties-demo-api.properties,DEFAULT_GROUP'}, BootstrapPropertySource {name='bootstrapProperties-demo-api,DEFAULT_GROUP'}, BootstrapPropertySource {name='bootstrapProperties-common-i18n.properties,I18N_GROUP'}, BootstrapPropertySource {name='bootstrapProperties-redis.properties,DATABASE_GROUP'}, BootstrapPropertySource {name='bootstrapProperties-mysql.properties,DATABASE_GROUP'}]

4. 項目規(guī)劃

這里談談一個項目創(chuàng)建時,有關nacos config相關配置規(guī)劃的想法。

1. 分配置文件

項目本地配置文件的功能分類:

  • bootstrap-{profile} :主要存放 nacos 的環(huán)境信息,不同環(huán)境下的nacos服務器地址可能不同。
  • bootstrap :存放 nacos 與環(huán)境無關的基礎信息,如 shared-configs[n]、extension-configs 等,以及服務名稱、端口號等。
  • application-{profile} :主要用于開發(fā)環(huán)境的配置,本地開發(fā)時有些參數(shù)不希望直接改公共的 nacos,可以在配置文件中修改。
  • application :本地開發(fā)時,存放與環(huán)境無關的基礎信息。

總體來說,在開啟nacos config服務后,都是以服務器上 ${prefix}-${spring.profile.active}.${file-extension}為準。本地application的作用及其有限,除非滿足一些特殊的本地開發(fā)場景需求。

2. 分環(huán)境

雖然可以在一個nacos服務器上,通過${prefix}-${spring.profile.active}.${file-extension}來分環(huán)境,但不建議這么做。

不同環(huán)境nacos的服務器健壯程度、安全保密程度等,都是有不同要求的。一般建議在一個nacos服務器上,根據(jù)不同環(huán)境,連接不同的 namespace。甚至,根據(jù)不同環(huán)境,連接不同的nacos服務器。

我目前常用的做法,就是項目工程中不存放 application 相關的配置文件,只保留 bootstrap.properties 文件。不同環(huán)境下的配置文件是完全通過不同的nacos服務器或namespace來區(qū)分的,在本地運行時或 DevOps 部署時,通過傳遞參數(shù)來運行。例如本地運行時 Program arguments 的配置:

--nacos.url=http://x.x.x.x:xxxx
--nacos.config.namespace=xxx
--spring.cloud.nacos.discovery.enabled=false
--rocketmq.consumer-enabled=false

3. 分項目

通過 GROUP 來區(qū)分項目。而多個項目公用的一些配置,可獨立出幾個 GROUP,如:數(shù)據(jù)庫連接配置、多語言配置等。

5. CAP

我們知道分布式 cap 理論中,只能滿足 cp 或 ap。就注冊中心而言分類如下:

  • eureka 實現(xiàn)的是ap;
  • zookeeper(基于 paxos算法)、consul(基于 raft算法) 實現(xiàn)的是 cp;
  • nacos 既能實現(xiàn) ap,也能實現(xiàn) cp(基于 raft算法)。

nacos 集群默認支持的是 cap 原則中的 ap 原則。但是Nacos 集群可切換為CP原則,切換命令如下:

curl -X PUT '$NACOS_SERVER:8848/nacos/v1/ns/operator/switches?entry=serverMode&value=CP'

同時,微服務的 bootstrap.properties 還需配置如下選項,指明注冊為臨時/永久實例。 AP模式不支持數(shù)據(jù)一致性,所以只支持服務注冊的臨時實例,CP模式支持服務注冊的永久實例,滿足配置文件的一致性

#false為永久實例,true表示臨時實例開啟,注冊為臨時實例
spring.cloud.nacos.discovery.ephemeral=true

以上就是Nacos配置文件使用經(jīng)驗及CAP規(guī)則詳解的詳細內(nèi)容,更多關于Nacos配置文件CAP的資料請關注腳本之家其它相關文章!

相關文章

  • 使用IntelliJ IDEA調(diào)式Stream流的方法步驟

    使用IntelliJ IDEA調(diào)式Stream流的方法步驟

    本文主要介紹了使用IntelliJ IDEA調(diào)式Stream流的方法步驟,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • Spring Security OAuth2認證授權示例詳解

    Spring Security OAuth2認證授權示例詳解

    這篇文章主要介紹了Spring Security OAuth2認證授權示例詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-09-09
  • 淺談Java線程間通信方式

    淺談Java線程間通信方式

    這篇文章主要為大家詳細介紹了Java線程間的通信方式,以代碼結(jié)合文字的方式來討論線程間的通信,感興趣的朋友可以參考一下
    2021-11-11
  • SpringBoot參數(shù)驗證的幾種方式小結(jié)

    SpringBoot參數(shù)驗證的幾種方式小結(jié)

    在日常的接口開發(fā)中,為了防止非法參數(shù)對業(yè)務造成影響,經(jīng)常需要對接口的參數(shù)進行校驗,例如登錄的時候需要校驗用戶名和密碼是否為空,所以本文介紹了SpringBoot參數(shù)驗證的幾種方式,需要的朋友可以參考下
    2024-07-07
  • Spring?MVC內(nèi)置過濾器功能示例詳解

    Spring?MVC內(nèi)置過濾器功能示例詳解

    這篇文章主要為大家介紹了Spring?MVC內(nèi)置過濾器使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-09-09
  • mybatis自動生成時如何設置不生成Example類詳解

    mybatis自動生成時如何設置不生成Example類詳解

    這篇文章主要給大家介紹了關于mybatis自動生成時如何設置不生成Example類的相關資料,文中介紹的非常詳細,對大家具有一定的參考學習價值,需要的朋友們下面來一起看看吧。
    2017-05-05
  • Java使用OpenFeign管理多個第三方服務調(diào)用

    Java使用OpenFeign管理多個第三方服務調(diào)用

    最近開發(fā)了一個統(tǒng)一調(diào)度類的項目,需要依賴多個第三方服務,這些服務都提供了HTTP接口供我調(diào)用。感興趣的可以了解一下
    2021-06-06
  • springBoot集成Elasticsearch 報錯 Health check failed的解決

    springBoot集成Elasticsearch 報錯 Health check failed的解決

    這篇文章主要介紹了springBoot集成Elasticsearch 報錯 Health check failed的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • java使用elasticsearch分組進行聚合查詢過程解析

    java使用elasticsearch分組進行聚合查詢過程解析

    這篇文章主要介紹了java使用elasticsearch分組進行聚合查詢過程解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-02-02
  • 詳解spring boot中使用JdbcTemplate

    詳解spring boot中使用JdbcTemplate

    JdbcTemplate 是在JDBC API基礎上提供了更抽象的封裝,并提供了基于方法注解的事務管理能力。 通過使用SpringBoot自動配置功能并代替我們自動配置beans,下面給大家介紹spring boot中使用JdbcTemplate相關知識,一起看看吧
    2017-04-04

最新評論