Nacos配置文件使用經(jīng)驗及CAP原則詳解
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流的方法步驟,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-05-05Spring Security OAuth2認證授權示例詳解
這篇文章主要介紹了Spring Security OAuth2認證授權示例詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-09-09SpringBoot參數(shù)驗證的幾種方式小結(jié)
在日常的接口開發(fā)中,為了防止非法參數(shù)對業(yè)務造成影響,經(jīng)常需要對接口的參數(shù)進行校驗,例如登錄的時候需要校驗用戶名和密碼是否為空,所以本文介紹了SpringBoot參數(shù)驗證的幾種方式,需要的朋友可以參考下2024-07-07Java使用OpenFeign管理多個第三方服務調(diào)用
最近開發(fā)了一個統(tǒng)一調(diào)度類的項目,需要依賴多個第三方服務,這些服務都提供了HTTP接口供我調(diào)用。感興趣的可以了解一下2021-06-06springBoot集成Elasticsearch 報錯 Health check failed的解決
這篇文章主要介紹了springBoot集成Elasticsearch 報錯 Health check failed的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-08-08java使用elasticsearch分組進行聚合查詢過程解析
這篇文章主要介紹了java使用elasticsearch分組進行聚合查詢過程解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-02-02