Apollo兜底口诀

Apollo 的兜底是"命名空间是否在目标集群有发布记录"的判断

(有发布就不兜底;没发布才回退到default集群)。

sql 复制代码
判断的是"有无发布",不是"里面有没有配置项"。

✅ Apollo 配置兜底顺序表(集群 + 命名空间 + 默认 application)

优先级 查找目标 命名空间是否存在并发布? 兜底逻辑说明 最终生效来源
1️⃣ 当前集群(如 dev)的 显式命名空间 (例:app.yaml, redis.yaml ✅ 已发布(哪怕为空) 直接使用该集群的版本,不兜底 dev/namespace
2️⃣ 当前集群(如 dev)的 显式命名空间 ❌ 未发布 回退到 default 集群的同名命名空间 default/namespace
3️⃣ 当前集群的 默认命名空间 application.properties ✅ 已发布 作为通用兜底配置(自动加载,无需声明) dev/application.properties
4️⃣ 当前集群的 默认命名空间 application.properties ❌ 未发布 回退到 default/application.properties default/application.properties
5️⃣ 本地配置文件(application.yaml/properties --- 被 Apollo 上述配置覆盖(若 overrideLocalProperties=true 本地
6️⃣ Spring 默认值 --- 最底层兜底(如 Redis 默认 localhost:6379) 框架默认

Tips : springboot项目不用显示加载 application.properties,内部自动加载

🧠 小结口诀(更新版)

命名空间有发布 → 不兜底命名空间没发布 → 兜底到 default 集群application.properties 永远会被加载,不用写在 namespaces 里本地配置与默认值只在 Apollo 都找不到时才生效


🧩 Tips:Apollo 命名空间兜底逻辑

✅ application(properties)是系统保留命名空间,会自动加载、自动兜底;

⚠️ application.yaml 只是普通命名空间,不会自动兜底,需手动写入

yaml 复制代码
apollo.bootstrap.namespaces: application.yaml, app.yaml

💡 简记:

properties 版自动上场,yaml 版要点名上场。

相关推荐
一线大码4 小时前
开发 Java 项目时的命名规范
java·spring boot·后端
程序员小假4 小时前
什么是线程池?它的工作原理?
java·后端
chenchihwen4 小时前
RAG 多模态 API 处理系统设计解析:企业级大模型集成架构实战
架构
盖世英雄酱581364 小时前
java 深度调试【第一章:堆栈分析】
java·后端
lastHertz4 小时前
Golang 项目中使用 Swagger
开发语言·后端·golang
渣哥4 小时前
面试高频:Spring 事务传播行为的核心价值是什么?
javascript·后端·面试
调试人生的显微镜4 小时前
iOS 代上架实战指南,从账号管理到使用 开心上架 上传IPA的完整流程
后端
本就一无所有 何惧重新开始5 小时前
Redis技术应用
java·数据库·spring boot·redis·后端·缓存
低音钢琴5 小时前
【SpringBoot从初学者到专家的成长11】Spring Boot中的application.properties与application.yml详解
java·spring boot·后端