SpringCloud 核心组件Nacos【配置热更新&配置共享】第5章

310 阅读3分钟

1:配置热更新 在SpringCloud 核心组件Nacos【配置管理&配置拉取】第4章

中已经讲述了在nacos中构建配置文件,服务启动时拉取nacos中的配置,但我们的最终目的,是修改nacos中的配置,使服务不需要重启即可让配置生效,也就是配置的热更新!!!

要实现配置热更新,可以使用两种方式:

1.1:方式一 在@Value注入的变量所在类上添加注解@RefreshScope

​​

@RestController @RequestMapping("/config") @RefreshScope public class ConfigController { @Value("${czxy.message}") private String msg;

/**
 * http://localhost:8072/config/get
 */
@GetMapping("/get")
public String get() {
    return msg;
}

}

进行测试:

第一步:看看nacos配置文件中的内容 (爱吃豆的土豆)

​​

第二步:获取内容

​​

第三步:修改nacos配置文件中的配置内容为:(Java让人心碎)

​​

nacos修改文件进行发布:

​​

第四步:不重启服务直接进行请求,看是否得到新的配置内容(Java让人心碎)

​​

1.2:方式二 使用@ConfigurationProperties注解代替@Value注解。

在config-service服务中,添加一个类,读取czxy.message属性:

​​

@Component @Data @ConfigurationProperties(prefix = "czxy") public class PatternProperties { private String message; } @ConfigurationProperties:该注解通过扫描配置配置文件中的配置前缀和属性名保持一致完成内容的注入,这里前缀是czxy,属性名是message,映射到nacos配置文件中的czxy.message

@Data:Lombok注解生成get,set方法

@Component:把这个类注册成spring的一个bean这样一来就可以任意使用这个类了

测试类的代码:

@RestController @RequestMapping("/config") //@RefreshScope public class ConfigController { @Resource private PatternProperties patternProperties; // @Value("${czxy.message}") // private String msg;

/**
 * http://localhost:8072/config/get
 */
@GetMapping("/get")
public String get() {
    return patternProperties.getMessage();
}

}

进行测试:

第一步:看看nacos配置文件中的内容 (Java让人心碎)

​​

第二步:查看内容

​​

第三步:修改nacos配置文件中的配置内容为:(快让我涨点粉吧!)

​​

​​

第四步:不重启服务直接进行请求,看是否得到新的配置内容(快让我涨点粉吧!)

​​

总结:两种方式实现配置的热更新,记得加入哪种方式时重启一下服务,使刚加入的热更新方式生效,两种方式:第二种更为广泛!!

2.配置共享 其实微服务启动时,会去nacos读取多个配置文件,例如:

[spring.application.name]-[spring.profiles.active].yaml,例如:userservice-dev.yaml

[spring.application.name].yaml,例如:userservice.yaml

而[spring.application.name].yaml不包含环境,因此可以被多个环境共享。

下面我们通过案例来测试配置共享

1)添加一个环境共享配置 我们在nacos中添加一个configservice.yaml文件:

2)在configservice中读取共享配置 在configservice服务中,修改PatternProperties类,读取新添加的属性

在configservice服务中,修改ConfigController,添加一个方法:

@GetMapping("/prop") public PatternProperties prop() { return patternProperties; } 3)运行两个ConfigApplication,使用不同的profile 修改ConfigApplication2这个启动项,改变其profile值:

这样,ConfigService(8071)使用的profile是test,ConfigService2(8082)使用的profile是dev。

启动ConfigService和ConfigService2

访问http://localhost:8071/config/prop,结果:

访问http://localhost:8072/config/prop,结果:

可以看出来,不管是dev,还是test环境,都读取到了envSharedValue这个属性的值。

4)配置共享的优先级 当nacos、服务本地同时出现相同属性时,优先级有高低之分:

测试文件优先级

测试本地application.yml文件 在本地application.yml文件中添加一个变量参数进行测试

server: port: 8071 czxy: name: 本地环境local 注入配置:

测试:访问

测试:Nacos配置中心的configservice.yaml优先级 和本地application.yml文件的优先级

进行重新测试访问:

结果:共享文件将本地的application.yml文件中相同的数据进行覆盖掉了,由此可得出nacos中的共享文件优先级大于本地优先级

测试:Nacos配置中心的服务名-profile.yaml优先级 修改nacos中的环境文件

因为配置了热更新,可直接进行访问

可以看出nacos中的(服务名-profile.yaml)文件将以上两种文件相同属性内容进行了覆盖!

优先级:

① [ 服务名 ]-[ 环境 ]. yaml >[ 服务名 ]. yaml > 本地配置

3:多服务共享配置 不同微服务之间可以共享配置文件,通过下面的两种方式来指定:

方式一: server: port: 8071 spring: application: name: configservice #服务名称 profiles: active: dev #环境 cloud: nacos: config: server-addr: localhost:8848 #Nacos地址 file-extension: yaml #文件后缀名 shared-configs: #多微服务间共享的配置文件 - data-id: common.yaml #要共享的配置文件id 方式二: server: port: 8071 spring: application: name: configservice #服务名称 profiles: active: dev #环境 cloud: nacos: config: server-addr: localhost:8848 #Nacos地址 file-extension: yaml #文件后缀名 extension-configs: # 多微服务间共享的配置列表 - dataId: extend.yaml # 要共享的配置文件id 多种配置的优先级:

优先级:

① 环境配置 > 服务名 . yaml > extension-config > extension-configs > shared-configs > 本地配置