Spring Cloud 整合 nacos实现动态配置中心的详细步骤

2022-11-13 19:11:36 整合 配置 步骤

上一篇文章讲解了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>

版本nacos2.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控制台添加配置列表:

设置dataIdnacos-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,那就需要新建一个dataIdnacos-config-client.properties配置。

4.2 手动设置 dataId

NacosConfigProperties类里面name字段就是配置dataId

public class NacosConfigProperties {
  
	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原生注解 @RefreshScopecontroller直接调用即可:

@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注解。

源码

GitHub源码

参考文献

Nacos 融合 Spring Cloud,成为注册配置中心

nacos属性值@Value自动刷新

到此这篇关于Spring Cloud 整合 nacos 实现动态配置中心的文章就介绍到这了,更多相关Spring Cloud 整合 nacos内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

相关文章