手摸手教程—Nacos动态配置中心
1、前言
我们使用一门技术时首先要弄懂为啥要用它,它可以帮我们解决哪些问题。
nacos配置中心,可以使得配置标准化、格式统一化,当配置信息发生变动时,修改实时生效,无需要重新重启服务器,就能够自动感知相应的变化,并将新的变化统一发送到相应程序上,快速响应变化。
本文基于Cloud Alibaba 2021.0.1.0 + Springboot 2.6.3
2、实操
nacos的下载与安装这里就不说了。nacos-server默认是集群模式启动,这里我们使用单机模式。
startup.cmd -m standalone
新建项目后 先添加依赖
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
<version>2021.0.1.0</version>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bootstrap</artifactId>
<version>3.1.2</version>
</dependency>
这里需要注意,该版本不再默认加载bootstrap 文件,如果需要加载bootstrap 文件需要手动添加依赖。
之后我们去nacos的控制台新建一个命名空间
如此得到一个命名空间的id,紧接着去项目中的配置文件填写。
spring:
cloud:
nacos:
config:
server-addr: 服务ip:8848
file-extension: yaml
namespace: 434e7801-0b5d-4fd2-b96a-acbac849fd84
application:
name: nacos-demo
profiles:
active: dev
再去nacos控制台,在配置列表选中我们刚刚新建的命名空间,点最右侧+号
这里我们按步骤走,需要注意的就是Data Id
写个测试接口,启动项目,我们来测试一下
@RefreshScope
@RestController
public class ConfigController {
@Value("${user.name}")
private String name;
@GetMapping("/test")
public String test(){
return name;
}
}
首先我们发现项目是以8082端口启动
调用接口后
我们注意到在控制类上有个**@RefreshScope** 该注解可以帮助实现配置热加载。
我们修改配置文件后,不重启项目,重新调用接口
3、解析
实操后肯定有很多疑问,此时我们再来解析一下:
Data Id: 它的取值为前缀-环境-扩展名
spring.cloud.nacos.config.prefix−{spring.cloud.nacos.config.prefix}-spring.cloud.nacos.config.prefix−{spring.profiles.active}.${spring.cloud.nacos.config.file-extension}
- prefix:前缀,默认是 spring.application.name 的值。取值优先级为先取 spring.cloud.nacos.config.prefix,再取 spring.cloud.nacos.config.name,最后取spring.application.name,拿到一个值就行了。
- active:配置运行环境,即为当前环境对应的 profile。当 spring.profiles.active 为空时,对应的连接符 ”-“ 也将不存在,dataId 的拼接格式变成 prefix.{prefix}.prefix.{file-extension}
- file-exetension:配置文件的类型,默认是 properties,也可以通过配置项 spring.cloud.nacos.config.file-extension 来配置,目前支持的类型有 TEXT、JSON、XML、YAML、HTML、Properties
NameSpace: 其实从实例中我们也能看出来, Nacos 引入命名空间 Namespace 的概念来进行多环境配置和服务的管理及隔离。例如,你可能存在本地开发环境dev、测试环境test、生产环境prod 三个不同的环境,那么可以创建三个不同的 Namespace 区分不同的环境。
**Group:**比较细粒度的隔离,比如用户微服务单独分组USER_GROUP
转载自:https://juejin.cn/post/7227020874889478204