一、如何使用nacos的配置中心
1.引入nacos配置中心依赖
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
<version>2.2.5.RELEASE</version>
</dependency>
2.修改工程配置文件(配置中心相关配置项)
spring:
cloud:
nacos:
server-addr: 10.110.77.71:8848
username: nacos
password: nacos2023@gop
# 配置中心
config:
file-extension: yaml
prefix: dgov-inside-manage
# 服务注册与发现
discovery:
server-addr: ${spring.cloud.nacos.server-addr}
单纯对于配置中心来说,可以想象到的配置包括地址、用户名、密码,根据下图配置类定义可以看出,这些配置默认继承于spring.cloud.nacos层级下的server-addr、username、password,命名空间spring.cloud.nacos.config.namespace默认为public,分组spring.cloud.nacos.config.group默认为DEFAULT_GROUP
3.在nacos控制台中添加对应配置
二、nacos配置中心的配置和本地配置覆盖关系
涉及到Spring底层多配置源加载,相关类MutablePropertySources,暂不详细讨论,结论是:
本地及Nacos配置中心共同加载顺序为:
1.bootstrap.yaml
2.bootstrap.properties
3.bootstrap-{profile}.yaml
4.bootstrap-{profile}.properties
5.application.yaml
6.application.properties
7.application-{profile}.yaml
8.application-{profile}.properties
9.nacos配置中心共享配置(通过spring.cloud.nacos.config.shared-configs指定)
10.Nacos配置中心该服务配置(通过spring.cloud.nacos.config.prefix和spring.cloud.nacos.config.file-extension指定)
11.Nacos配置中心该服务-{profile}配置(通过spring.cloud.nacos.config.prefix和spring.cloud.nacos.config.file-extension、以及spring.profiles.active指定)
配置生效覆盖关系:
对于key名相同,后加载会覆盖掉前加载,故而最终为后加载的配置项生效!
对于key名不同,则直接生效(会加载,但不会被覆盖);
三、nacos配置中心原理
1.基础
基于SpringCloud提供的自定义配置接口-PropertySourceLocator通过重写locate方法,将配置提供给SpringCloud,返回是一个PropertySource类型(PropertySource抽象类)的对象,如下图所示
2.nacos配置方式
nacos配置中心的核心类是NacosPropertySourceLocator,该类实现PropertySourceLocator接口,重写locate方法,返回对象是CompositePropertySource,该类中有个Set<PropertySource>类型的属性,这里的PropertySource,nacos用的是NacosPropertySource,Set使用的是LinkedHashSet,所以根据顺序后面加载的配置会覆盖前面的配置,如下图所示:
上面的CompositePropertySource和NacosPropertySource都是PropertySource的实现类,继承关系如下图所示:
上面的所有类中,属于nacos定义的是NacosPropertySourceLocator和NacosPropertySource
配置加载使用到了三个方法
loadSharedConfiguration(composite);
loadExtConfiguration(composite);
loadApplicationConfiguration(composite, dataIdPrefix, nacosConfigProperties, env);
依次加载共享配置,扩展配置,应用配置,配置依旧是覆盖关系。