带有spring cloud config的consul第一个bootstrap

时间:2016-04-14 17:24:33

标签: spring-boot config spring-cloud service-discovery consul

我使用spring-cloud-config进行集中配置,并使用consul进行服务发现。像eureka第一个bootstrap一样 - spring支持consul第一个bootstrap,即在启动客户端服务时 - 我应该通过consul查找配置服务器。反过来非常合适,即在配置客户端bootstrap.properties中 - 我提供了spring.cloud.config.uri = http://localhost:8888,它位于配置服务器并从中提取配置。在我的客户端应用程序的配置库中 - 我提供了consul配置,如:

spring.cloud.consul.host=localhost , 
spring.cloud.consul.port=8500

然而,当我尝试使用consul第一个bootstrap时,我无法从配置服务器读取属性。

客户端应用程序(用于首次引导):

pom.xml
<parent>
      <groupId>org.springframework.cloud</groupId>
      <artifactId>spring-cloud-starter-parent</artifactId>
      <!-- <version>Brixton.BUILD-SNAPSHOT</version> -->
      <version>Brixton.M5</version>
      <relativePath /> 
    </parent>
<dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-aop</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.retry</groupId>
            <artifactId>spring-retry</artifactId>
        </dependency>
     <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-consul-config</artifactId>
        </dependency> 
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-consul-all</artifactId>
        </dependency>
<dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-zuul</artifactId>
        </dependency>
</dependencies>

bootstrap.properties:

spring.application.name=demo
spring.cloud.config.failFast=true
spring.cloud.config.retry.maxAttempts=20
spring.cloud.config.retry.initialInterval=3000
spring.cloud.consul.host=localhost
spring.cloud.consul.port=8500

DemoApplication.java

@EnableDiscoveryClient
@EnableZuulProxy
@SpringBootApplication
public class DemoSleuthApplication {
    public static void main(String[] args) {
        SpringApplication.run(DemoSleuthApplication.class, args);
    }
}
@RefreshScope
@RestController
class RestAPIController 
{
    @Value(value = "${server.port}")
    String port;

    @Value(value = "${message}")
    String message;

@RequestMapping("/message")
      public String welcome(){
          String s = this.restTemplate.getForObject("http://localhost:"+this.port+"/message", String.class);
          return this.message + s;
      }
}

在领事K / V商店 文件夹结构config / demo 键/值:spring.cloud.config.uri=http://localhost:8888

配置服务器git repo:为简洁起见,不添加配置服务器代码 demo.properties

server.port=9080
message=test

理想情况下,当我实现consul第一个bootstrap的概念时 - 我认为应该启动consul并且客户端应该使用@EnableDiscoveryClien t注释并在consul属性中查找自己 - 查找配置服务器URL,并获取配置服务器配置的属性。但在我的情况下,服务正在consul中被发现和注册,但我无法从配置服务器git repo读取属性。

2 个答案:

答案 0 :(得分:2)

完成了here。它可以在SNAPSHOTS和RC2中使用,它将在下周出现。

答案 1 :(得分:0)

在此处提供我的示例代码以造福他人。我不得不做很多修改属性文件来实现这个目标。 正如@spencergibb所回答的那样,目前仅在SNAPSHOT中提供。

这次我没有在领事中使用任何键值属性。 配置服务器代码: pom.xml中:

<dependency>
   <groupId>org.springframework.cloud</groupId>
   <artifactId>spring-cloud-config-server</artifactId>
 </dependency>
 <dependency>
     <groupId>org.springframework.cloud</groupId>
     <artifactId>spring-cloud-starter-consul-all</artifactId>
  </dependency>
 <dependency>
   <groupId>org.springframework.cloud</groupId>
   <artifactId>spring-cloud-consul-discovery</artifactId>
 </dependency>

application.yml

 spring:
    profiles:
     active: native
    cloud:
     config:
       server:
        native:
          search-locations: file://${HOME}/properties 
    consul:
      port: 8500
      host: localhost
      enabled: true
      discovery:
        enabled: true
        register: true
        service-name: server --registers in consul as server instead of config-server 
        hostname: localhost
server:
  port: 8888

bootstrap.yml ::

spring:
  application:
    name: config-server

COnfigServerApplication.java

@EnableDiscoveryClient
@EnableConfigServer
@SpringBootApplication
public class SpringConfigServerApplication {
public static void main(String[] args) {
  SpringApplication.run(SpringConfigServerApplication.class, args);
 }
}

客户端微服务:演示

<parent>
   <groupId>org.springframework.cloud</groupId>
   <artifactId>spring-cloud-starter-parent</artifactId>
   <version>Brixton.BUILD-SNAPSHOT</version>
 <!--   <version>Brixton.M5</version> -->
   <relativePath /> 
 </parent>
<dependency>
   <groupId>org.springframework.cloud</groupId>
   <artifactId>spring-cloud-starter-config</artifactId>
 </dependency>
<dependency>
   <groupId>org.springframework.cloud</groupId>
   <artifactId>spring-cloud-starter-consul-all</artifactId>
 </dependency>

bootstrap.properties

spring.application.name=demo-spring-cloud-sleuth
spring.cloud.config.failFast=true
spring.cloud.config.retry.maxAttempts=20
spring.cloud.config.retry.initialInterval=3000
spring.cloud.config.enabled=true
spring.cloud.config.discovery.enabled=true
spring.cloud.config.discovery.serviceId=config-server
spring.cloud.consul.discovery.hostName=localhost
spring.cloud.consul.discovery.register=true -- unless this is there, the service fails to register in consul.

客户端的git uri属性文件:

server.port=9082
message=message local
foo1=bar