上篇学习nacos作为注册中心的使用,而nacos还可以作为微服务中的配置中心,本文将手把手教你如何进行搭建配置中心

代码地址:https://gitee.com/webprogram/springcloud_learn

Nacos配置管理

统一配置管理

当我们的系统分为很多服务时,当你更改某个配置时,需要重新每个服务逐个去修改,然后重新部署,过程繁琐而微服务中的配置管理中心就是为了解决这一问题,服务会向配置中心读取相关配置,进行热部署

配置方式

springcloud nacos指定dataId springcloud nacos配置中心_微服务

springcloud nacos指定dataId springcloud nacos配置中心_环境配置_02

Data ID: 配置文件的id,[服务名]-[profile].[后缀名]
Group: 分组,默认即可
配置内容: 一般添加一些开关类型、经常变动的配置

配置加载过程

springcloud nacos指定dataId springcloud nacos配置中心_环境配置_03

  • 普通项目加载顺序:项目启动->读取本地配置文件->常见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;
    }

springcloud nacos指定dataId springcloud nacos配置中心_spring_04

springcloud nacos指定dataId springcloud nacos配置中心_微服务_05

如上图对比,接口已经成功读取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.[服务名].[后缀] 默认配置,多环境共享变量

两种类型配置方式和之前一致

多环境配置优先级

当本地配置、特定环境配置、共享配置中存在同一变量时,程序最终读到的是哪个呢?

  • 优先级: 特定环境配置 > 共享配置 > 本地配置,即在这三处都配置了同一个配置的话,最终程序读取的是特定环境下的配置