Spring Cloud整合配置中心Eureka中的服务状态显示UNKOWN

栏目: Java · 发布时间: 7年前

内容简介:今天在研究Spring Cloud的配置中心的时候,发现将应用的配置移到git上,启动应用后发现,在Euraka注册中心上这个应用的状态始终为UNKOWN,可是这个应用是可以提供服务的。下面是应用的bootstrap的配置:日志打印应用的状态:这些配置肯定没有什么问题,因为这些配置在没有挪到bootstrap.yml中之前都是可以正常使用的。现在Eureka注册中心却不能检测到应用的状态,这样让我百思不得其解。后来我在stackoverflow上找到了答案

今天在研究Spring Cloud的配置中心的时候,发现将应用的配置移到git上,启动应用后发现,在Euraka注册中心上这个应用的状态始终为UNKOWN,可是这个应用是可以提供服务的。下面是应用的bootstrap的配置:

spring:
  application:
    name: search-provider
  cloud:
    config:
      name: search-config
      profile: dev
      label: master
      discovery:
        enabled: true
        service-id: config-server
eureka:
    client:
        fetch-registry: true
        register-with-eureka: true
        healthcheck:
           enabled: true
        service-url:
          defaultZone: http://xxxx:xxxx@xxx.ydstudio.net:xxx/eureka/
    instance:
        #instance-id默认值是主机名:应用名:应用端口 instance-id: ${spring.application.name}:${random.value}
        #instance-id: ${spring.cloud.client.ipAddress}:${server.port}
        instance-id: ${spring.cloud.client.ipAddress}:${spring.application.name}:${server.port}
        hostname: ${spring.cloud.client.ipAddress}
        #hostname: ${spring.application.name}
        # 默认30s,表示eureka client发送心跳给server端的频率
        lease-renewal-interval-in-seconds: 15
        # 默认90s,表示eureka server至上一次收到client的心跳之后,等待下一次心跳的超时时间,在这个时间内若没收到下一次心跳,则将移除该instance
        lease-expiration-duration-in-seconds: 25
        # 将自己的ip显示到EuekaServer上
        prefer-ip-address: true

日志打印应用的状态:

StatusChangeEvent [timestamp=1536481926709, current=UNKNOWN, previous=UP]

这些配置肯定没有什么问题,因为这些配置在没有挪到bootstrap.yml中之前都是可以正常使用的。现在Eureka注册中心却不能检测到应用的状态,这样让我百思不得其解。后来我在stackoverflow上找到了答案

stackoverflow地址 ,问题只有一个答案,其中重要内容如下:

eureka.client.healthcheck.enabled=true should only be set in  application.yml. Setting the value in bootstrap.yml will cause undesirable side effects like registering in eureka with an  UNKNOWN status.

知道这一点后我将bootstrap.yml中的内容修改如下面一样:

spring:
  application:
    name: search-provider
  cloud:
    config:
      name: search-config
      profile: dev
      label: master
      #uri: http://localhost:9008
      discovery:
        enabled: true
        service-id: config-server

eureka:
    client:
        fetch-registry: true
        register-with-eureka: true
        healthcheck:
           enabled: true
        service-url:
          defaultZone: http://xxxx:xxxx@xxx.ydstudio.net:xxx/eureka/

在Eureka注册中心中应用的状态就显示正常了!

最后更新于 2018-09-09 17:40:25 并被添加「spring cloud eureka」标签,已有 3 位童鞋阅读过。


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Redis开发与运维

Redis开发与运维

付磊、张益军 / 机械工业出版社 / 2017-3-1 / 89.00

本书全面讲解Redis基本功能及其应用,并结合线上开发与运维监控中的实际使用案例,深入分析并总结了实际开发运维中遇到的“陷阱”,以及背后的原因, 包含大规模集群开发与管理的场景、应用案例与开发技巧,为高效开发运维提供了大量实际经验和建议。本书不要求读者有任何Redis使用经验,对入门与进阶DevOps的开发者提供有价值的帮助。主要内容包括:Redis的安装配置、API、各种高效功能、客户端、持久化......一起来看看 《Redis开发与运维》 这本书的介绍吧!

SHA 加密
SHA 加密

SHA 加密工具

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具