springboot本地配置覆盖apollo配置

1.apollo包的版本(2.0.0)

<dependency>
    <groupId>com.ctrip.framework.apollo</groupId>
    <artifactId>apollo-client</artifactId>
    <version>2.0.0</version>
</dependency>
<dependency>
    <groupId>com.ctrip.framework.apollo</groupId>
    <artifactId>apollo-core</artifactId>
    <version>2.0.0</version>
</dependency>

2.apollo配置的优先级源码解析

主要是两个文件:com.ctrip.framework.apollo.spring.boot.ApolloApplicationContextInitializer和com.ctrip.framework.apollo.spring.config.PropertySourcesProcessor

(1)ApolloApplicationContextInitializer.class

会将apollo配置放到environment的first,如下代码environment.getPropertySources().addFirst(composite):

@Override
  public void initialize(ConfigurableApplicationContext context) {
    ConfigurableEnvironment environment = context.getEnvironment();

    if (!environment.getProperty(PropertySourcesConstants.APOLLO_BOOTSTRAP_ENABLED, Boolean.class, false)) {
      logger.debug("Apollo bootstrap config is not enabled for context {}, see property: ${
  
  {}}", context, PropertySourcesConstants.APOLLO_BOOTSTRAP_ENABLED);
      return;
    }
    logger.debug("Apollo bootstrap config is enabled for context {}", context);

    initialize(environment);
  }


  /**
   * Initialize Apollo Configurations Just afte
### 如何在 Spring Boot 项目中通过 Apollo 配置 Debug 日志级别 #### 1. 确保 Apollo 自动注入功能开启 为了使 Apollo 能够优先加载配置,需在 `application.properties` 或 `application.yml` 文件中启用 Apollo 的自动注入功能: ```yaml apollo.bootstrap.enabled: true apollo.bootstrap.eagerLoad.enabled: true ``` 以上配置确保 Apollo 在 Logback 初始化之前完成配置加载[^1]。 --- #### 2. 在 Application.yml 中定义基础日志级别 尽管 Apollo 可以动态调整日志级别,但在本地开发或离线环境中仍需提供默认值。例如,在 `application.yml` 中设置全局日志级别为 `INFO`,并对特定模块单独设定更精细的日志级别: ```yaml logging: level: root: INFO com.example.myproject: DEBUG ``` 此处设置了根日志级别为 `INFO`,而针对自定义包路径 `com.example.myproject` 则设为 `DEBUG`[^2]。 --- #### 3. 创建 Apollo Namespace 并配置日志级别 登录 Apollo 控制台,进入目标应用的命名空间(Namespace),新增键值对来覆盖日志级别的配置。例如: ```properties logging.level.root=INFO logging.level.com.example.myproject=DEBUG ``` 上述配置表示将根日志级别设置为 `INFO`,并将 `com.example.myproject` 包下的日志级别提升至 `DEBUG`。 --- #### 4. 启用 Apollo Config 注解支持 在 Spring Boot 启动类上添加 `@EnableApolloConfig` 注解,以便框架能够识别并加载 Apollo 提供的配置项: ```java import com.ctrip.framework.apollo.spring.annotation.EnableApolloConfig; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication @EnableApolloConfig public class MyApplication { public static void main(String[] args) { SpringApplication.run(MyApplication.class, args); } } ``` 该注解的作用是让 Spring Boot 应用程序能够在运行时从 Apollo 获取最新的配置信息[^1]。 --- #### 5. 指定 Apollo 运行环境参数 通过 Java 系统属性指定 Apollo 的运行环境及相关配置,例如: ```bash -Denv=DEV -Dapp.id=my-spring-boot-app -Dconfig.service.url=http://your-apollo-config-service-url ``` 这些参数决定了应用程序连接哪个 Apollo 实例以及读取哪套配置数据[^1]。 --- #### 6. 校验配置是否生效 编写一段简单代码测试日志输出行为是否符合预期: ```java import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.stereotype.Component; @Component public class TestLogger { private static final Logger logger = LoggerFactory.getLogger(TestLogger.class); public void testLogging() { logger.debug("This is a DEBUG message from my custom package."); logger.info("This is an INFO message from my custom package."); } } ``` 启动应用后观察控制台输出,确认只有来自 `com.example.myproject` 下的 `DEBUG` 级别日志被打印出来,其余部分维持原有日志级别不变[^1]。 --- ### 注意事项 - 若发现日志未按预期显示,请检查 Apollo 配置是否正确加载,可通过调试模式查看实际使用的配置内容。 - 当存在多个配置来源冲突时,遵循以下优先级顺序:System Property > Environment Variable > Apollo Configuration > Local YAML/Properties File。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值