SpringCloud之Nacos,配置中心
上篇学习nacos作为注册中心的使用,而nacos还可以作为微服务中的配置中心,本文将手把手教你如何进行搭建配置中心
代码地址:https://gitee.com/webprogram/springcloud_learn
Nacos配置管理
统一配置管理
当我们的系统分为很多服务时,当你更改某个配置时,需要重新每个服务逐个去修改,然后重新部署,过程繁琐而微服务中的配置管理中心就是为了解决这一问题,服务会向配置中心读取相关配置,进行热部署
配置方式
Data ID: 配置文件的id,[服务名]-[profile].[后缀名] Group: 分组,默认即可 配置内容: 一般添加一些开关类型、经常变动的配置
配置加载过程
-
普通项目加载顺序:项目启动->读取本地配置文件->常见spring容器->加载bean 微服务加载过程如上图,首先会加载Nacos配置,然后和本地配置做合并,故启动的时候得知道Nacos地址,从bootstrap.yml中获取
代码中配置流程
<!-- Nacos配置管理依赖--> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId> </dependency>
# 在对应服务目录resources目录下新建bootstrap.yml文件,这个文件是引导文件,会优先于application.yml文件加载 # 下面例子中[服务名]-[开发环境].[后缀名] 对应 在Nacos管理页面新建配置的Data ID spring: application: name: userservice # 服务名称 profiles: active: dev # 开发环境,这里是dev cloud: nacos: # nacos配置 server-addr: 127.0.0.1:8848 # nacos地址 config: file-extension: yaml # 文件后缀名
# 测试代码 # 读取Nacos配置中心的配置 @Value("${myconfig.testmessage}") private String testMessage; @RequestMapping("/testconfig") public String getConfig(){ return "Nacos配置:" + testMessage; }
如上图对比,接口已经成功读取Nacos的配置
配置热更新
Nacos的配置文件变更后,微服务无需重启就可以感知,通过如下两种方式配置:
方法1 在@Value注入的变量所在类上添加@RefreshScope
@RestController @RefreshScope // 配置刷新 public class UserController { }
方法2 使用@ConfigurationProperties注解
// 配置@ConfigurationProperties类读取注解 @Data @Component @ConfigurationProperties(prefix = "myconfig") public class PropertiesConfig { private String testMessage; } // 在使用配置的类中注入PropertiesConfig即可 @Autowired private PropertiesConfig propertiesConfig; @RequestMapping("/testconfig") public String getConfig(){ return "Nacos配置:" + propertiesConfig.getTestMessage(); }
配置共享
多环境配置共享
微服务启动时会在Nacos中读取两个配置文件: 1.[服务名]-[spring.profile.active].[后缀] 特定环境配置(如dev,test,prod)2.[服务名].[后缀] 默认配置,多环境共享变量
两种类型配置方式和之前一致
多环境配置优先级
当本地配置、特定环境配置、共享配置中存在同一变量时,程序最终读到的是哪个呢?
-
优先级: 特定环境配置 > 共享配置 > 本地配置,即在这三处都配置了同一个配置的话,最终程序读取的是特定环境下的配置