Apollo兜底口诀

11 阅读1分钟

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

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

判断的是“有无发布”,不是“里面有没有配置项”。

✅ 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.propertiesdefault/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 只是普通命名空间,不会自动兜底,需手动写入

apollo.bootstrap.namespaces: application.yaml, app.yaml

💡 简记:

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