SpringCloudAliBaba之Nacos配置中心:轻松管理配置文件

简介: SpringCloudAliBaba之Nacos配置中心:轻松管理配置文件

1、Nacos配置中心使用

官方文档:https://github.com/alibaba/spring-cloud-alibaba/wiki/Nacos-config

Nacos提供用于存储配置和其他元数据的key/value存储,为分布式系统中的外部化配置提供服务器和客户端支持。使用Spring Cloud Alibaba Nacos Config,你可以在Nacos Server集中管理你Spring Cloud 应用的外部属性配置。

springcloud config 对比

三大优势

  • springcloud config大部分场景结合git使用,动态变更还需要依赖Spring Cloud Bus 消息总线来通过所有的客户端变化。
  • springclound config不提供可视化界面
  • nacos config使用长轮询配置,一旦配置变更,通知Provide的过程非常的迅速,从速度上秒杀springcloud config几条街

1.1、快速开始

准备配置,nacos server中新建nacos-config.properties

Data ID:    nacos-config.properties
Group  :    DEFAULT_GROUP
配置格式:    Properties
配置内容:   user.name=齐菁菁
            user.age=123456

注意:dataid是以properties(默认的文件扩展名方式)为扩展名

客户端使用方式

创建一个标准的SpringBoot项目,并引入依赖

<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>

启动项:

@SpringBootApplication
public class ConfigApplication {
    public static void main(String[] args) {
        ConfigurableApplicationContext applicationContext = SpringApplication.run(ConfigApplication.class, args);
        String userName = applicationContext.getEnvironment().getProperty("user.name");
        String userAge = applicationContext.getEnvironment().getProperty("user.age");
        System.err.println("user name :"+userName+"; age: "+userAge);
    }
}

在运行此 Example 之前, 必须使用 bootstrap.properties 配置文件来配置Nacos Server 地址,例如:

bootstrap.properties

spring.application.name=nacos-config
spring.cloud.nacos.config.server-addr=127.0.0.1:8848

启动这个 Example,可以看到如下输出结果:

user name :齐菁菁; age: 123456

2、基于 dataid 为 yaml 的文件扩展名配置方式

spring-cloud-starter-alibaba-nacos-config 对于 yaml 格式也是完美支持的。这个时候只需要完成以下两步:

1、在应用的 bootstrap.properties配置文件中显示的声明 dataid 文件扩展名。如下所示

spring:
  cloud:
    nacos:
      config:
        #修改默认配置文件扩展名(默认是properties)
        file-extension: yaml

2、新建一个dataid为yml的配置

Data ID:        nacos-config.yaml
Group  :        DEFAULT_GROUP
配置格式:        YAML
配置内容:        user:
              name: nacos-config.yaml
                  age: 68

这两步完成后,重启测试程序,可以看到如下输出结果。

2018-11-02 14:59:00.484  INFO 32928 --- [main] 
user name :nacos-config-yaml; age: 68
2018-11-02 14:59:00.529  INFO 32928 --- [-127.0.0.1:8848]

3、支持配置的动态更新

spring-cloud-starter-alibaba-nacos-config 也支持配置的动态更新,启动 Spring Boot 应用测试的代码如下:

@SpringBootApplication
public class ConfigApplication {
    public static void main(String[] args) {
        ConfigurableApplicationContext applicationContext = SpringApplication.run(ConfigApplication.class, args);
        while(true) {
            //当动态配置刷新时,会更新到 Enviroment中,因此这里每隔一秒中从Enviroment中获取配置
            String userName = applicationContext.getEnvironment().getProperty("user.name");
            String userAge = applicationContext.getEnvironment().getProperty("user.age");
            System.err.println("user name :" + userName + "; age: " + userAge);
            TimeUnit.SECONDS.sleep(1);
        }
    }
}

如下所示,当变更user.name时,应用程序中能够获取到最新的值:

user name :齐菁菁; age: 123456
user name :齐菁菁; age: 123456
2022-06-26 20:11:16.652  WARN 10812 --- [34.254.160_8847] o.s.c.e.event.RefreshEventListener       : Refresh keys changed: [user.name]
user name :qijingjing; age: 123456
user name :qijingjing; age: 123456
user name :qijingjing; age: 123456
user name :qijingjing; age: 123456

你可以通过配置 spring.cloud.nacos.config.refresh.enabled=false 来关闭动态刷新

4、可支持profile粒度的配置

spring-cloud-starter-alibaba-nacos-config 在加载配置的时候,不仅仅加载了以 dataid 为 ${spring.application.name}.${file-extension:properties} 为前缀的基础配置,还加载了dataid为 ${spring.application.name}-${profile}.${file-extension:properties} 的基础配置。在日常开发中如果遇到多套环境下的不同配置,可以通过Spring 提供的 ${spring.profiles.active} 这个配置项来配置。

spring:
  profiles:
    active: develop

Nacos 上新增一个dataid为:nacos-config-develop.yaml的基础配置,如下所示:

Data ID:        nacos-config-develop.yaml
Group  :        DEFAULT_GROUP
配置格式:        YAML
配置内容:        current.env: develop-env

启动 Spring Boot 应用测试的代码如下:

@SpringBootApplication
public class ConfigApplication {
    public static void main(String[] args) {
        ConfigurableApplicationContext applicationContext = SpringApplication.run(ConfigApplication.class, args);
        while(true) {
            String userName = applicationContext.getEnvironment().getProperty("user.name");
            String userAge = applicationContext.getEnvironment().getProperty("user.age");
            //获取当前部署的环境
            String currentEnv = applicationContext.getEnvironment().getProperty("current.env");
            System.err.println("in "+currentEnv+" enviroment; "+"user name :" + userName + "; age: " + userAge);
            TimeUnit.SECONDS.sleep(1);
        }
    }
}

启动后,可见控制台的输出结果:

in develop-env enviroment; user name :nacos-config.yaml; age: 68

结论:我们的nacos-config.yamlnacos-config-develop.yaml都起到了作用

知识补充:profile>默认配置文件,优先级大的会覆盖优先级小的,然后形成互补

如果需要切换环境(例如生产环境),只需要更改${spring.profiles.active}参数配置即可。同时在Nacos添加dataid为:nacos-config-product.yaml的配置即可

5、支持自定义 namespace 的配置

最佳配置:

  • namespace:代表不同环境,如开发、测试、生产环境
  • group: 代表项目,如XX医疗项目,XX电商项目
  • dataid:每个项目下面有若干个微服务,每个配置集(dataid)是一个微服务的主配置文件

在nacos server里面创建一个新的命名空间,例如dev

在没有明确指定 ${spring.cloud.nacos.config.namespace} 配置的情况下, 默认使用的是 Nacos 上 Public 这个namespae。如果需要使用自定义的命名空间,可以通过以下配置来实现:

spring:
  cloud:
    nacos:
      config:
        # 默认命名空间是public,这里需要填写dev命名空间的环境值
        namespace: f5fa5d97-b3df-4e3e-8aa6-6ad7bc3640bf

然后克隆几个配置文件到dev环境,启动类测试运行即可。

注意:该配置必须放在 bootstrap.yml文件中。此外 spring.cloud.nacos.config.namespace 的值是 namespace 对应的 id,id 值可以在 Nacos 的控制台获取。并且在添加配置时注意不要选择其他的 namespae,否则将会导致读取不到正确的配置。

6、支持自定义 Group 的配置

在没有明确指定 ${spring.cloud.nacos.config.group} 配置的情况下, 默认使用的是 DEFAULT_GROUP 。如果需要自定义自己的 Group,可以通过以下配置来实现:

spring:
  cloud:
    nacos:
      config:
        # 组(默认是DEFAULT_GROUP)
        group: STORE_GROUP

克隆配置文件到这个STORE_GROUP组即可

注意:该配置必须放在 bootstrap.yml文件中。并且在添加配置时 Group 的值一定要和 spring.cloud.nacos.config.group 的配置值一致。

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

在之前的基础上加入新的代码:

spring:
  cloud:
    nacos:
      config:
        shared-configs:
          - data-id: com.lili.store.properties
            #不指定的话默认为DEFAULT_GROUP
            group: STORE_GROUP
            # 自定读取刷新配置
            refresh: true
        extension-configs[0]:
          data-id: com.lili.store1.properties
          #不指定的话默认为DEFAULT_GROUP
          group: STORE_GROUP
          # 自定读取刷新配置
          refresh: true

添加两个配置:

Data ID:        com.lili.store.properties
Group  :        STORE_GROUP
配置格式:        properties
配置内容:        user.sex=男
Data ID:        com.lili.store1.properties
Group  :        STORE_GROUP
配置格式:        properties
配置内容:        user.sex=女

启动测试类

@SpringBootApplication
public class ConfigApplication {
    public static void main(String[] args) throws InterruptedException {
        ConfigurableApplicationContext applicationContext = SpringApplication.run(ConfigApplication.class, args);
        while(true) {
            String userName = applicationContext.getEnvironment().getProperty("user.name");
            String userAge = applicationContext.getEnvironment().getProperty("user.age");
            String userSex = applicationContext.getEnvironment().getProperty("user.sex");
            //获取当前部署的环境
            String currentEnv = applicationContext.getEnvironment().getProperty("current.env");
            System.err.println("in "+currentEnv+" enviroment; "+"user name :" + userName + "; age: " + userAge + ";sex: "+ userSex);
            TimeUnit.SECONDS.sleep(1);
        }
    }
}

结果:

in dev-namespace enviroment; user name :nacos-namespace.yaml; age: 68;sex: 女

8、配置的优先级

profile > 默认配置文件 > extension-configs(下标越大优先级越大) > shard-configs(下标越大优先级越大)

9、补充@RefreshScope

@Value注解可以获取到配置中心的值,但是无法动态感知修改后的值,需要利用@RefreshScope注解即可

@RestController
@RefreshScope
public class HelloController {
    @Value("${user.name}")
    private String name;
    @RequestMapping("/show")
    public String hello(){
        return this.name;
    }
}

目录
相关文章
|
8天前
|
存储 网络协议 Nacos
高效搭建Nacos:实现微服务的服务注册与配置中心
Nacos(Dynamic Naming and Configuration Service)是阿里巴巴开源的一款动态服务发现、配置管理和服务管理平台。它旨在帮助开发者更轻松地构建、部署和管理分布式系统,特别是在微服务架构中。
170 81
高效搭建Nacos:实现微服务的服务注册与配置中心
|
24天前
|
JSON Java Nacos
SpringCloud 应用 Nacos 配置中心注解
在 Spring Cloud 应用中可以非常低成本地集成 Nacos 实现配置动态刷新,在应用程序代码中通过 Spring 官方的注解 @Value 和 @ConfigurationProperties,引用 Spring enviroment 上下文中的属性值,这种用法的最大优点是无代码层面侵入性,但也存在诸多限制,为了解决问题,提升应用接入 Nacos 配置中心的易用性,Spring Cloud Alibaba 发布一套全新的 Nacos 配置中心的注解。
144 12
|
2月前
|
Java 网络安全 Nacos
Nacos作为流行的微服务注册与配置中心,其稳定性与易用性广受好评
Nacos作为流行的微服务注册与配置中心,其稳定性与易用性广受好评。然而,“客户端不发送心跳检测”是使用中常见的问题之一。本文详细探讨了该问题的原因及解决方法,包括检查客户端配置、网络连接、日志、版本兼容性、心跳检测策略、服务实例注册状态、重启应用及环境变量等步骤,旨在帮助开发者快速定位并解决问题,确保服务正常运行。
51 5
|
2月前
|
监控 Java 测试技术
Nacos 配置中心变更利器:自定义标签灰度
本文是对 MSE Nacos 应用自定义标签灰度的功能介绍,欢迎大家升级版本进行试用。
174 12
|
2月前
|
网络安全 Nacos 开发者
Nacos作为流行的微服务注册与配置中心,“节点提示暂时不可用”是常见的问题之一
Nacos作为流行的微服务注册与配置中心,其稳定性和易用性备受青睐。然而,“节点提示暂时不可用”是常见的问题之一。本文将探讨该问题的原因及解决方案,帮助开发者快速定位并解决问题,确保服务的正常运行。通过检查服务实例状态、网络连接、Nacos配置、调整健康检查策略等步骤,可以有效解决这一问题。
41 4
|
2月前
|
Java 网络安全 Nacos
Nacos作为流行的微服务注册与配置中心,其稳定性和易用性备受青睐。
Nacos作为流行的微服务注册与配置中心,其稳定性和易用性备受青睐。然而,实际使用中常遇到“客户端不发送心跳检测”的问题。本文深入探讨该问题的原因及解决方案,帮助开发者快速定位并解决问题,确保服务正常运行。通过检查客户端配置、网络连接、日志、版本兼容性、心跳策略、注册状态、重启应用和环境变量等步骤,系统地排查和解决这一问题。
58 3
|
2月前
|
安全 Nacos 数据库
Nacos是一款流行的微服务注册与配置中心,但直接暴露在公网中可能导致非法访问和数据库篡改
Nacos是一款流行的微服务注册与配置中心,但直接暴露在公网中可能导致非法访问和数据库篡改。本文详细探讨了这一问题的原因及解决方案,包括限制公网访问、使用HTTPS、强化数据库安全、启用访问控制、监控和审计等步骤,帮助开发者确保服务的安全运行。
73 3
|
6月前
|
Java Nacos 数据库
使用 nacos 搭建注册中心及配置中心
使用 nacos 搭建注册中心及配置中心
110 5
|
6月前
|
NoSQL Java Nacos
SpringCloud集成Seata并使用Nacos做注册中心与配置中心
SpringCloud集成Seata并使用Nacos做注册中心与配置中心
189 3
|
2月前
|
负载均衡 应用服务中间件 Nacos
Nacos配置中心
Nacos配置中心
122 1
Nacos配置中心