1

所以我最近学习了 Spring Cloud 这个很棒的配置服务,经过一番努力,我能够设置我们的分布式应用程序,多个节点从一个配置服务器读取配置属性。

但是我不知道如何解决的一个问题是,即使大多数道具在多个节点上都是相同的,但有些道具需要本地版本,我不知道如何将本地道具与配置服务一起设置。

例如这是我的bootstrap.properties

spring.cloud.config.uri=${config.server:http://localhost:8888}
spring.application.name=worker

bootstrap.properties如果我在单独的文件下或在单独的文件中添加其他道具application.properties,我可以在执行器的 env 端点下看到它们,如下所示,

configService:file:///home/me/work/config-test/worker.properties: 
{
    server.timeout: "100"
},

applicationConfig: [classpath:/application.properties]: {
    server.timeout: "50"
},

在我的应用程序中,server.timeout现在总是 100,我不知道当我使用这样的集中配置服务时如何引用本地值?

4

2 回答 2

1

好的,经过更多研究,我找到了答案。来自https://docs.pivotal.io/spring-cloud-services/config-server/configuration-clients.html

Spring 应用程序可以使用 Config Server 作为属性源。来自配置服务器的属性将覆盖那些在本地定义的(例如通过类路径中的 application.yml)。

因此,正确的做法是将任何客户端属性排除在配置服务之外。这对我来说也意味着对于这样的属性,没有办法有一个默认值,只有当客户端值出现时才会被覆盖,这很好。

于 2016-09-02T01:16:53.917 回答
0

从官方文档中的覆盖远程属性的值部分:

通过引导上下文添加到您的应用程序的属性源通常是“远程的”(例如来自配置服务器),并且默认情况下它们不能在本地覆盖,除非在命令行上。如果您想允许您的应用程序使用自己的系统属性或配置文件覆盖远程属性,则远程属性源必须通过设置授予它权限spring.cloud.config.allowOverride=true(在本地设置此设置不起作用)。

一旦设置了该标志,就会有一些更细粒度的设置来控制远程属性相对于系统属性和应用程序本地配置的位置:spring.cloud.config.overrideNone=true用任何本地属性源覆盖,并且spring.cloud.config.overrideSystemProperties=false如果只有系统属性和环境变量应该覆盖远程设置,但不是本地配置文件。

因此,您可以在远程(例如远程 git 存储库)中设置以下配置,application.yml以允许本地覆盖远程属性。

spring:
  cloud:
    config:
      allowOverride: true
      overrideNone: true
      overrideSystemProperties: false
于 2019-03-19T00:03:01.210 回答