上篇学习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.[服务名].[后缀] 默认配置,多环境共享变量
两种类型配置方式和之前一致
多环境配置优先级
当本地配置、特定环境配置、共享配置中存在同一变量时,程序最终读到的是哪个呢?
- 优先级: 特定环境配置 > 共享配置 > 本地配置,即在这三处都配置了同一个配置的话,最终程序读取的是特定环境下的配置