Nacos2.0 配置中心管理,动态配置更新
Posted bitters
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Nacos2.0 配置中心管理,动态配置更新相关的知识,希望对你有一定的参考价值。
前言
Nacos除了可以做注册中心,同样可以做配置中心来使用。
当微服务部署的实例越来越多,达到数十、数百时,逐个修改微服务配置就会让人抓狂,而且很容易出错。我们需要一种统一配置管理方案,可以集中管理所有实例的配置。
当前nacos还提供了配置的历史查询以及监听、版本管理等功能,总的来说功能还是很强大的
Nacos2 Config的升级
Nacos1.0配置管理之前用 Http1.1 的 Keep Alive 模式 30s 发一个心跳模拟长链接,协议难以理解,内存消耗大,推送性能弱,因此 2.0 通过 gRPC 彻底解决这些问题,内存消耗大量降低
Confg配置的实现
启动Nacos注册中心
引入jar
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
创建项目
编写bootstrap.yml和application.yml配置文件,bootstrap的配置文件运行时级别比application要高
在springboot2020.0.0以上的版本默认不会去读取bootstrap配置文件,因此要引入
<!-- 2020.0.0 版本不在默认加载bootstrap 文件 -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bootstrap</artifactId>
</dependency>
bootstrap.yml
# nacos配置
spring:
application:
name: nacos-config-client
cloud:
nacos:
discovery:
server-addr: localhost:8848 #Nacos服务注册中心地址
config:
server-addr: localhost:8848 #Nacos作为配置中心地址
file-extension: yaml #指定yaml格式的配置
application.yml
spring:
profiles:
active: dev # 表示开发环境
创建config配置文件,在Nacos注册中心中
登陆nacos中创建配置文件
新建页面
- 命名空间
解决多环境及多租户数据的隔离问题 在多套不同的环境下,可以根据指定的环境创建不同的Namespace,实现多环境的数据隔离。 Nacos中默认提供的命名空间则是public。 - GREOUP
Nacos 中的一组配置集,是组织配置的维度之一,简单的说则是不同的系统或微服务的配置文件可以放在一个组里。 Nacos如果不指定Group,则默认的分组是DEFAULT_GROUP。 - Data ID
dataId是一个配置的唯一标识。 格式:spring.profiles.active.$file-extension
创建后的效果
配置内容
config:
info: nacos-config-client-dev.yaml,version = 4
创建Controller
@RefreshScope 必段加上,不然不会刷新配置
//支持Nacos的动态刷新功能。
public class ConfigClientController
("$config.info")
private String info;
("/get")
public String get()
return "获取的config配置下的值为" + info;
运行效果
刷新配置
当要修改config时,会提示更新的内容,点击【确认发布】后
控制监控内容发生变化,已经刷新了配置的值,不过注意,如把数据库的配置或者端口之类的加在配置文件中,那可能需要重启才会生效了,下图配置已更新
其他
欢迎有问题及时交流~
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多交流
以上是关于Nacos2.0 配置中心管理,动态配置更新的主要内容,如果未能解决你的问题,请参考以下文章
Alibaba中间件技术系列「Nacos技术专题」配置中心加载原理和配置实时更新原理分析(上)