Spring Cloud 整合 nacos 實現動態配置中心
- 2022 年 10 月 31 日
- 筆記
上一篇文章講解了Spring Cloud
整合 nacos
實現服務註冊與發現,nacos
除了有服務註冊與發現的功能,還有提供動態配置服務的功能。本文主要講解Spring Cloud
整合nacos
實現動態配置服務。主要參考官方部署手冊點我。
前提條件
先下載nacos
並啟動nacos
服務。操作步驟詳見Nacos 快速入門。
整合步驟
1. 添加依賴
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
<version>2.2.7.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<version>2.2.12.RELEASE</version>
</dependency>
版本
nacos
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
依賴版本要和nacos
服務端版本要一致。
2. 新建 nacos 配置
在nacos
控制台添加配置列表:
設置dataId
為nacos-config
,文件後綴為Properties
,設置內容user.name=jack
:
3. bootstrap.properties 配置
在application.yml
同目錄下創建bootstrap.yml
文件,並配置Nacos
服務地址以及namespace
(沒有就不需要配置):
spring:
application:
name: nacos-config-client
cloud:
nacos:
config:
server-addr: 127.0.0.1:8848
namespace: 68468122-8955-45ee-a5b7-3d87972325b1
4. 配置dataId
dataId
對應步驟2
裡面的dataId
,有兩種配置方式,一種是官方自動構建dataId
,另一種是指定dataId
。
4.1 自動配置 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.profiles.active
為空時,對應的連接符 – 也將不存在,dataId
的拼接格式變成${prefix}.${file-extension}
file-exetension
為配置內容的數據格式,可以通過配置項spring.cloud.nacos.config.file-extension
來配置。目前只支援properties
和yaml
類型。
比如項目名稱為nacos-config-client
,當前環境為test
,格式文件為properties
,那就需要新建一個dataId
為nacos-config-client.properties
配置。
4.2 手動設置 dataId
在NacosConfigProperties
類裡面name
欄位就是配置dataId
:
public class NacosConfigProperties {
/**
* nacos config dataId name.
*/
private String name;
//省略其他配置
}
在bootstrap.yml
添加spring.cloud.nacos.config.name
就可以設置dataId
。
5.獲取數據
通過@Value
就能獲取配置文件的數據:
@Component
@RefreshScope
public class TestConfig {
@Value(value = "${user.name:null}")
private String test;
public String getTest(){
return test;
}
要實現配置的自動更新,需要添加Spring Cloud
原生註解 @RefreshScope
。controller
直接調用即可:
@RestController
public class TestController {
@Autowired
private TestConfig testConfig;
@GetMapping("/config")
public String testConfig(){
String config = testConfig.getTest();
return config;
}
}
如果想通過@NacosValues
註解獲取數據,需要引入nacos-config-spring-boot-starter
依賴:
<dependency>
<groupId>com.alibaba.boot</groupId>
<artifactId>nacos-config-spring-boot-starter</artifactId>
<version>0.2.7</version>
</dependency>
總結
nacos-config
配置首先添加spring-cloud-starter-alibaba-nacos-config
依賴。- 在配置列表添加配置
bootstrap.properties
添加nacos server
地址和namespace
- 配置
dataId
有兩種方式- 手動配置,配置
spring.cloud.nacos.config.name
- 自動配置,根據
${prefix}-${spring.profiles.active}.${file-extension}
規則配置,其中prefix
為項目名稱,spring.profiles.active
為項目運行環境,file-extension
配置內容的數據格式。
- 手動配置,配置
- 通過
@Value(value = "${user.name:null}")
設置在欄位上就能獲取到屬性,要實現自動更新配置需要添加@RefreshScope
註解。