您好,登錄后才能下訂單哦!
這篇文章主要介紹“SpringCloud怎么使用Nacos保存和讀取變量的配置”,在日常操作中,相信很多人在SpringCloud怎么使用Nacos保存和讀取變量的配置問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”SpringCloud怎么使用Nacos保存和讀取變量的配置”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
在使用SpringCloud開發微服務時,經常會遇到一些比較小的后臺參數配置,這些配置不足以單獨開一張表去存儲,而且其他服務會讀取該參數。比如IP白名單。這時,使用Nacos去保存和讀取就比較方便。
使用SpringCloud的項目
啟動Nacos
添加依賴:
<dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId> <version>${latest.version}</version> </dependency
注意:版本 2.1.x.RELEASE 對應的是 Spring Boot 2.1.x 版本。版本 2.0.x.RELEASE 對應的是 Spring Boot 2.0.x 版本,版本 1.5.x.RELEASE 對應的是 Spring Boot 1.5.x 版本。
參考:Nacos版本說明Wiki
在微服務的配置中配置Nacos server的地址和應用名
spring: application: name: service-xxx cloud: nacos: config: server-addr: ${spring.cloud.nacos.discovery.server-addr} file-extension: yaml
說明:
之所以需要配置spring.application.name
,是因為它是構成 Nacos 配置管理dataId
字段的一部分。
在 Nacos Spring Cloud 中,dataId
的完整格式如下:
${prefix}-${spring.profiles.active}.${file-extension}
prefix 默認為spring.application.name
的值,也可以通過配置項spring.cloud.nacos.config.prefix
來配置。
spring.profiles.active
即為當前環境對應的profile
,詳情可以參考Spring Boot文檔。
注意:當spring.profiles.active
為空時,對應的連接符-
也將不存在,dataId
的拼接格式變成${prefix}.${file-extension}
file-exetension
為配置內容的數據格式,可以通過配置項spring.cloud.nacos.config.file-extension
來配置。目前只支持properties
和yaml
類型。
按照上面配置好Nacos作為配置中心后,就可以通過在配置類上增加SpringCloud原生注解,開啟自動從Nacos取值,例如
@Value 直接注入變量值
@ConfigurationProperties 將若干變量整合到一個Properties類中
注意:
要啟用自動同步Nacos變量的變化,需要在注入變量的類上增加@RefreshScope
注解
Nacos也提供了與之對應的自己特有的注解。
Spring Cloud注解 | Nacos Spring 注解 | 備注 |
---|---|---|
@Value | @NacosValue | auto-refreshed |
@ConfigurationProperties | @NacosConfigurationProperties | auto-refreshed, @NacosProperty 對某一個屬性進行設置, @NacosIgnore Nacos忽略該值 |
一般來說,我們注入變量,都是把變量放在微服務的配置文件中,例如application.yaml
,但是有時候,我們想單獨把某些配置保存為一個nacos的配置,即:有獨立的dataId
,這時,我們需要用到extension-configs
例如,有如下配置:
@Component @RefreshScope @ConfigurationProperties(prefix = "test") public class TestProperties { private List<String> whiteList; public List<String> getWhiteList() { return whiteList; } public void setWhiteList(List<String> whiteList) { this.whiteList = whiteList; } }
我們想在nacos上創建一個test.properties
的配置存放該Properties的值,那么就需要修改微服務的配置文件:
spring: application: name: service-xxx cloud: nacos: config: server-addr: ${spring.cloud.nacos.discovery.server-addr} file-extension: yaml extension-configs[0]: data-id: test.properties refresh: true
extension-configs[n]
可以增加多個,每一個包含三個配置:
data-id
獨立的data-id
,必須以properties
或yaml
結尾,不受spring.cloud.nacos.config.file-extension
影響
group
該配置獨立的group
refresh
是否啟用自動刷新,默認false
這樣,就實現了獨立的配置文件的nacos配置和其值自動更新。
在上面的基礎上,我們再增加一個功能:微服務從本地修改變量值,并上傳到nacos,其他相同微服務實例,取值時都會拿到相同值,那就需要調用nacos的原生APINacosConfigManager
了
//將本地配置推送到Nacos configManager.getConfigService().publishConfig("test.properties", "DEFAULT_GROUP", contentToString(ConfigType.PROPERTIES)); //從Nacos拉取配置 configManager.getConfigService().getConfig("test.properties", "DEFAULT_GROUP", 100l)
1.假設當前微服務有兩個實例: A和B,我們在A上,通過publishConfig
將TestProperties
的值更新到了Nacos,那么另一個實例B,會收到Nacos的通知,從nacos獲取到最新的值,但是,這中間會有一個毫秒級的延遲。
2.Nacos也提供了例如@NacosInject
、ConfigService
等API,但是這些API只能在SpringBoot中使用,在SpringCloud中是無法直接使用的。
到此,關于“SpringCloud怎么使用Nacos保存和讀取變量的配置”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。