分布式微服务--Nacos作为配置中心(补)关于bosststrap.yml与@RefreshScope

一、关于bosststrap.yml

bootstrap.ymlapplication.yml 的区别

对比项 bootstrap.yml application.yml
加载时机 优先于 application.yml 加载(启动早期) 程序初始化完成后加载
主要用途 设置应用的外部配置源注册中心信息 设置应用内部配置,如端口、日志级别、bean 配置等
使用场景 需要在程序启动早期就完成配置加载的情况 常规配置

✅ Nacos 配置中心为什么推荐用 bootstrap.yml

Spring Cloud Alibaba 的配置加载机制,是基于 Spring Cloud Config 客户端架构 实现的,读取远程配置的行为是发生在应用上下文启动之前

🚨 也就是说:如果你把 Nacos 的配置写到 application.yml,此时还没加载配置中心,自然就读取不到远程配置。

所以要写到 bootstrap.yml


✅ 实际建议(记住这个就行):

凡是涉及到外部配置源(如 Nacos 配置中心、Spring Cloud Config Server、Apollo 等)的信息,必须写在 bootstrap.yml 中。

比如这些字段:

java 复制代码
spring:
  application:
    name: nacos-config-demo
  cloud:
    nacos:
      config:
        server-addr: 127.0.0.1:8848
        file-extension: yaml

✅ Spring Boot 3.x 的变化(附加知识)

从 Spring Boot 2.4 开始,引入了一个新的配置机制叫做 config 子系统 ,官方推荐使用 application.yml + configimport 替代 bootstrap.yml

比如你可以写成:

java 复制代码
spring:
  config:
    import: nacos:nacos-config-demo.yaml

但目前大多数 Spring Cloud Alibaba 项目依旧推荐 bootstrap.yml,特别是 Spring Boot 2.x 的项目。

一、@RefreshScope注解

✅为什么需要 @RefreshScope

在使用 Nacos 作为配置中心时,我们常常希望在不重启服务的情况下,动态刷新配置项的值 。Spring Cloud 提供了 @RefreshScope 注解来实现这个需求。

默认情况下,Spring 容器中注入的配置值(如通过 @Value@ConfigurationProperties)在应用启动后就被固定了,即使 Nacos 中的配置发生了变更,也不会自动刷新,除非重启服务。

因此:

@RefreshScope 的作用就是:

让被注解的类或 Bean 在配置变更时,能够自动重新加载最新的配置,实现配置的热更新。


✅加在哪里?

1. 用在配置类上(推荐)
java 复制代码
@RefreshScope
@Configuration
@ConfigurationProperties(prefix = "user")
public class UserConfig {
    private String name;
    private Integer age;
    // 省略 getter/setter
}

此时,如果 Nacos 中 user.nameuser.age 的配置发生变更,该类会自动重新加载配置。

2. 用在使用 @Value 的类上
java 复制代码
@RestController
@RefreshScope  // 必须加在类上
public class UserController {

    @Value("${user.name}")
    private String name;

    @GetMapping("/user/name")
    public String getName() {
        return name;
    }
}

注意:如果你用的是 @Value必须加在类上才会生效。加在字段上无效!


✅ 配合使用的前提

要使 @RefreshScope 生效,还需确保:

  1. Nacos 配置变更时已开启 自动刷新refresh: true)。

  2. 引入了必要依赖(Spring Cloud Alibaba Nacos Config)。

  3. 项目中引入了 Spring Boot Actuator,并暴露了 /actuator/refresh 接口(对于手动刷新场景)。

相关推荐
小马哥编程4 分钟前
【软考架构】滑动窗口限流算法的原理是什么?
java·开发语言·架构
饕餮争锋22 分钟前
Spring AOP原理简析
java·spring
okseekw31 分钟前
Maven从入门到实战:核心概念+配置详解+避坑指南
java·后端
tryxr35 分钟前
ReentrantLock 与 synchronized 的区别
java··reentrantlock
lang2015092836 分钟前
Kafka元数据缓存机制深度解析
分布式·缓存·kafka
西格电力科技1 小时前
面向工业用户的绿电直连架构适配技术:高可靠与高弹性的双重设计
大数据·服务器·人工智能·架构·能源
Java爱好狂.1 小时前
Java面试Redis核心知识点整理!
java·数据库·redis·分布式锁·java面试·后端开发·java八股文
北邮刘老师1 小时前
【智能体互联协议解析】ACPs/AIP为什么还在用“落后”的“中心化”架构?
网络·人工智能·架构·大模型·智能体·智能体互联网
sheji34161 小时前
【开题答辩全过程】以 基于Java的应急安全学习平台的设计与实现为例,包含答辩的问题和答案
java·开发语言·学习