Spring对于externalized configurations的加载有明确的顺序。
但是,对于来自Spring Cloud Config的配置似乎有明显的遗漏。有谁知道Spring Cloud Config在上面适合的位置
答案 0 :(得分:0)
文档指出:
引导程序属性在/ env端点中显示为高优先级属性源,如以下示例所示
所以它将是位置#0
答案 1 :(得分:0)
第12点和第14点涉及Spring Cloud Config。
12。打包的jar之外的特定于配置文件的应用程序属性(application- {profile} .properties和YAML变体)。
14。打包的jar之外的应用程序属性(application.properties和YAML变体)。
答案 2 :(得分:0)
正如其他人所述,配置服务器排在第一位。如果您尝试使用本地属性(即application-local.yml
)覆盖配置服务器的属性,则需要向配置服务器**添加两个属性:
spring.cloud.config.allowOverride=true
spring.cloud.config.overrideNone=true
由应用程序添加到您的应用程序的属性源 引导上下文通常是“远程”的(例如,来自Config Server),并且 默认情况下,它们不能在本地被覆盖。如果要允许您的应用程序覆盖远程 属性及其自己的系统属性或配置文件, 远程属性源必须通过设置授予它权限 spring.cloud.config.allowOverride = true(设置此项无效 本地)。设置该标志后,可以进行一些更精细的设置 控制与系统有关的远程属性的位置 属性和应用程序的本地配置: spring.cloud.config.overrideNone = true以使用任何本地替代 财产来源,以及 如果只有System,spring.cloud.config.overrideSystemProperties = false 属性和环境变量应覆盖远程设置,但不能 本地配置文件。
有关使用spring.cloud.config.override-system-properties=false
通过系统/命令行属性覆盖的信息,另请参见this。上面引用的文档存在不一致之处,我将其从引用中删除。
请注意,如果您希望远程配置服务器覆盖本地属性文件源而不是本地系统属性或环境属性,请在配置服务器中添加以下内容:
spring.cloud.config.allowOverride=true
spring.cloud.config.overrideNone=false
spring.cloud.config.overrideSystemProperties=false
**在这种情况下,overrideSystemProperties
值将被忽略。参见org.springframework.cloud.bootstrap.config.PropertySourceBootstrapConfiguration#insertPropertySources