1、環境搭建 1.1 依賴 <!-- nacos註冊中心 註解 @EnableDiscoveryClient --> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba- ...
1、環境搭建
1.1 依賴
<!-- nacos註冊中心 註解 @EnableDiscoveryClient -->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
<!-- nacos配置中心 -->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
1.2 bootstrap.properties 配置
# 埠
server.port=9607
# 服務名
spring.application.name=kgcmall96-nacos-config
# nacos 配置中心 的地址
spring.cloud.nacos.server-addr=127.0.0.1:8848
# 指定nacos配置中心支持的配置文件尾碼,註意:nacso上增加的配置文件尾碼要跟此處一致,預設值properties
spring.cloud.nacos.config.file-extension=yml
1.3 請求
/**
* Created On : 28/11/2022.
* <p>
* Author : huayu
* <p>
* Description: nacos配置中心測試入口
*/
@RestController
public class KgcMallNacosConfigController {
//單個讀取遠程配置中心的公共配置參數
@Value("${kh96.nacos.config:kh96-default}")
private String kh96NacosConfig;
/**
* @param : []
* @return : java.lang.String
* @author : huayu
* @date : 28/11/2022
* @description : 讀取遠程nacos配置中心添加的統一自定義配置,返回
*/
@GetMapping("/testNacosConfig")
public String testNacosConfig() {
return kh96NacosConfig;
}
}
1.4 添加遠程配置文件
1.4.1 添加
1.4.2 配置信息
1.4.3 添加成功
1.5 測試
1.6 修改配置信息
1.7 再次 測試
1.8 重啟項目測試
2、配置信息實時刷新
每次修改配置文件都需要重啟項目,十分麻煩,需要設置實時刷新;
2.1 添加註解
@RestController
@RefreshScope //nacos配置動態刷新註解
public class KgcMallNacosConfigController {
......
}
2.2 測試
3、批量讀取配置信息
3.1 配置類
/**
* Created On : 28/11/2022.
* <p>
* Author : huayu
* <p>
* Description: KgcMallNacosConfig
*/
@Configuration
@RefreshScope
@ConfigurationProperties(prefix = "kh96.nacos")
@Data
public class KgcMallNacosConfig {
/*
測試 批量讀取 配置信息
*/
private String config;
}
3.2 請求
/**
* Created On : 28/11/2022.
* <p>
* Author : huayu
* <p>
* Description: nacos配置中心測試入口
*/
@RestController
public class KgcMallNacosConfigController {
@Autowired
private KgcMallNacosConfig kgcMallNacosConfig;
/**
* @param : []
* @return : java.lang.String
* @author : huayu
* @date : 28/11/2022
* @description : 讀取遠程nacos配置中心添加的統一自定義配置,返回
*/
@GetMapping("/testNacosConfig")
public String testNacosConfig() {
//測試 批量讀取
return kgcMallNacosConfig.getConfig();
}
}
3.3 測試
4、讀取配置文件的組成
prefix-active-extension
prefix:首碼,預設為服務名
active:激活環境
extension:文件尾碼(propertion或者yml),需要跟配置中心一致
${spring.cloud.nacos.config.prefix}.${spring.profiles.active}.${spring.cloud.nacos.config.file-extension}
4.1 active指定配置環境
# 指定nacos配置中心支持的配置文件尾碼,註意:nacso上增加的配置文件尾碼要跟此處一致,預設值properties
spring.cloud.nacos.config.file-extension=yml
# 指定環境
# 配置文件首碼(預設以 服務名為首碼)
spring.cloud.nacos.config.prefix=config
## 指定激活環境
spring.profiles.active=test
# 最終拼接出來的就是 config-test-yml
4.2 添加配置文件
4.3 測試
5、命名空間 和 分組
5.1 添加命名空間
5.2 指定命名空間個分組
# 指定nacso配置中心的名稱空間,配置的是對應名稱空間的id值,不是名稱
# 官方建議:namespace名稱空間,作為環境區分,不同環境,使用不同的名稱空間
spring.cloud.nacos.config.namespace=0e35ec99-dfac-45eb-84bb-e9d8a35f726e
# 指定名稱空間下的分組,一般都是用於區分相同環境加的不同應用項目組,如果不配合配置,預設使用的是當前名稱空間下的預設分組DEFAULT_GROUP,也支持自定義分組
spring.cloud.nacos.config.group=KH96_GROUP
5.2.1 添加配置
6、配置文件級別
6.1 配置文件級別
主配置 > 擴展配置 > 共用配置
相同類型配置下,下標越大優先順序越高;
6.2 共用配置
6.2.1 配置信息
# nacos 的共用配置,此配置項是一個數組,數組的下標越大,優先順序越高,同等的共用配置,高優先順序自動覆蓋低優先順序
# 提醒:nacos所有的配置中,主配置存在的情況下,具有最高優先順序,同等配置不會被共分享配置覆蓋(所以先刪除主配置)
spring.cloud.nacos.config.shared-configs[0].data-id=kgcmall96-shared-config.yml
spring.cloud.nacos.config.shared-configs[0].group=KH96_GROUP
spring.cloud.nacos.config.shared-configs[0].refresh=true
6.2.2 添加配置文件
6.2.3 測試
需要先刪除主配置,因為它優先順序最高;
6.2.4 在配置一個共用配置,下標1
# 下標1覆蓋下標0的配置
spring.cloud.nacos.config.shared-configs[1].data-id=kgcmall96-priority-config.yml
spring.cloud.nacos.config.shared-configs[1].group=KH96_GROUP
spring.cloud.nacos.config.shared-configs[1].refresh=true
6.2.5 添加配置文件
6.2.6 測試
6.3 擴展配置
6.3.1 配置信息
## nacos擴展配置,此配置項是一個數組,數組的下標越大,優先順序越高,同等的共用配置,高優先順序自動覆蓋低優先順序
## 擴展配置的優先順序低於主配置,高於共用配置,如果某種場景下需要單獨覆蓋共用配置,就可以使用擴展配置,比如某個oracle,其他都意思mysql
spring.cloud.nacos.config.extension-configs[0].data-id=kgcmall96-extend-config.yml
spring.cloud.nacos.config.extension-configs[0].group=KH96_GROUP
spring.cloud.nacos.config.extension-configs[0].refresh=true