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 版要点名上场。

相关推荐
葫芦和十三5 小时前
图解 MongoDB 04|索引模型:每建一个索引,就是在 B+-tree 森林里多栽一棵
后端·mongodb·agent
用户47949283569156 小时前
claude Fable用不了?把Gpt 5.5pro接到你的claude code里
前端·后端
江米小枣tonylua6 小时前
译:设计生产级 RAG 架构
架构
GetcharZp8 小时前
告别 Nginx 复杂配置!这款带 Web 面板的万能代理神器,让端口转发变得如此简单
后端
IT_陈寒10 小时前
React的useState居然还有这种坑?我差点删库跑路
前端·人工智能·后端
nanxun88611 小时前
记一次诡异的 Docker 容器"串包"故障排查
java
Pedantic11 小时前
SwiftUI 手势笔记
前端·后端
金銀銅鐵11 小时前
[Python] 从《千字文》中随机挑选汉字
后端·python
怕浪猫12 小时前
领域特定语言(Domain-Specific Language, DSL)
设计模式·程序员·架构