spring-cloud-starter-alibaba-nacos-config 启动配置管理

1年前 (2023) 程序员胖胖胖虎阿
122 0 0

文章目录

        • 一、dataId 的完整格式
        • 二、支持自定义扩展的 Data Id 配置
        • 三、测试配置
          • 1、添加 maven 依赖
          • 2、config 示例配置
          • 3、Nacos 的控制台新增配置
          • 4、注入实体类
          • 5、调用接口
          • 6、测试结果
        • 四、配置的优先级
        • 五、完全关闭配置


nacos spring-cloud 参考地址:
https://nacos.io/zh-cn/docs/quick-start-spring-cloud.html


Spring Cloud Alibaba Nacos Config 参考地址:
https://github.com/alibaba/spring-cloud-alibaba/wiki/Nacos-config

版本对应说明: https://github.com/alibaba/spring-cloud-alibaba/wiki/版本说明

一、dataId 的完整格式

在 Nacos Spring Cloud 中,dataId 的完整格式如下:

${prefix}-${spring.profiles.active}.${file-extension}
  • prefix 默认为 spring.application.name 的值,也可以通过配置项 spring.cloud.nacos.config.prefix来配置。
  • 当 spring.profiles.active 为空时,对应的连接符 - 也将不存在,dataId 的拼接格式变成${prefix}.${file-extension}
  • file-exetension 为配置内容的数据格式,可以通过配置项 spring.cloud.nacos.config.file-extension 来配置。目前只支持 properties 和 yaml 类型。
    spring-cloud-starter-alibaba-nacos-config 启动配置管理

spring-cloud-starter-alibaba-nacos-config 查找文件为 Data Id 以及配置格式

二、支持自定义扩展的 Data Id 配置

extension-configs

# 多文件配置
shared-configs: [ spring-cloud-config-student.yaml,nacos-config.yaml ]

# 单文件配置, Data Id 指定分组组,设置动态刷新
spring.cloud.nacos.config.extension-configs[2].data-id=nacos-config.yaml
spring.cloud.nacos.config.extension-configs[2].group=REFRESH_GROUP
spring.cloud.nacos.config.extension-configs[2].refresh=true

shared-configs

# 多文件配置
extension-configs: [ spring-cloud-config-student.yaml,nacos-config.yaml ]

# 单文件配置, Data Id 指定分组组,设置动态刷新
spring.cloud.nacos.config.shared-configs[0].data-id=nacos-config.yaml
spring.cloud.nacos.config.shared-configs[0].group=GROUP_APP1
spring.cloud.nacos.config.shared-configs[0].refresh=true

三、测试配置

1、添加 maven 依赖

和 springboot 版本对应关系参考 https://github.com/alibaba/spring-cloud-alibaba/wiki/版本说明

        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
            <version>2.2.7.RELEASE</version>
        </dependency>
2、config 示例配置
server:
  port: 20002
spring:
  application:
    name: SPRING_CLOUD_SERVICE_CONFIG
  cloud:
    nacos:
      config:
        server-addr: 42.193.0.90:8848
        username: nacos
        password: nacos
        file-extension: yaml
        namespace: 2022-4-1-prod
        group: DEFAULT_GROUP
        refresh-enabled: true
        # prefix: nacos-config.yaml

        # extension-configs 和 shared-configs 下面这种写法不支持动态刷新(Data Id 在默认的组 DEFAULT_GROUP,默认不支持配置的动态刷新)
        # extension-configs: [ spring-cloud-config-student.yaml,nacos-config.yaml ]
        # shared-configs: [ spring-cloud-config-student.yaml,nacos-config.yaml ]
        extension-configs:
          - data-id: nacos-config.yaml
            group: DEFAULT_GROUP
            refresh: true
          - data-id: spring-cloud-config-student.yaml
            group: DEFAULT_GROUP
            refresh: true
3、Nacos 的控制台新增配置

spring-cloud-config-student.yaml 配置

student:
  address: 陕西-西安-新城区-尚德路-油泼面
  birthday: 2022-4-1
  password: 123456
  username: root

nacos-config.yaml 配置

user:
  age: 90
  name: spring-cloud-nacos-config-properties
4、注入实体类
@Data
@AllArgsConstructor
@NoArgsConstructor
@Component
@RefreshScope
public class Student {
    @Value("${student.username:admin}")
    private String username;
    @Value("${student.password:123456}")
    private String password;
    @Value("${student.address:shanghai}")
    private String address;
    @Value("${student.birthday:2022-02-22}")
    private String birthday;
}
5、调用接口
@RestController
@RequestMapping("/config")
@RefreshScope
public class ConfigController {
    @Autowired
    private Student student;

    @GetMapping("/student")
    public String getStudent() {
        return JSONObject.toJSONString(student);
    }
}
6、测试结果

http://127.0.0.1:20002/config/student 结果如下
spring-cloud-starter-alibaba-nacos-config 启动配置管理

四、配置的优先级

Spring Cloud Alibaba Nacos Config 目前提供了三种配置能力从 Nacos 拉取相关的配置。

其中 n 的值越大,优先级越高。

spring.cloud.nacos.config.extension-configs[n].data-id 的值必须带文件扩展名,文件扩展名支持 properties/yaml/yml。 此时 spring.cloud.nacos.config.file-extension 的配置对自定义扩展配置的 Data Id 文件扩展名没有影响。

  • A: 通过 spring.cloud.nacos.config.shared-configs[n].data-id 支持多个共享 Data Id 的配置

  • B: 通过 spring.cloud.nacos.config.extension-configs[n].data-id 的方式支持多个扩展 Data Id 的配置

  • C: 通过内部相关规则(应用名、应用名+ Profile )自动生成相关的 Data Id 配置

当三种方式共同使用时,他们的一个优先级关系是:A < B < C

五、完全关闭配置

通过设置 spring.cloud.nacos.config.enabled = false 来完全关闭 Spring Cloud Nacos Config

demo 地址:https://gitee.com/LingYunYe/nacos-example-study/tree/master/nacos-springcloud-config-examples/src/main

相关文章

暂无评论

暂无评论...