DiscoveryClient没有看到来自Eureka的服务

时间:2017-08-08 13:40:09

标签: spring-cloud netflix-eureka spring-cloud-netflix

当我向eureka询问它所知道的服务时(localhost:8071 / eureka / apps /),它说3是UP:

<applications>
  <versions__delta>1</versions__delta>
  <apps__hashcode>UP_3_</apps__hashcode>
  <application>
    <name>ROUTER</name>
    <instance>
      <instanceId>localhost:router:8765</instanceId>
      <hostName>localhost</hostName>
      <app>ROUTER</app>
      <ipAddr>10.0.75.1</ipAddr>
      <status>UP</status>
      <overriddenstatus>UNKNOWN</overriddenstatus>
      <port enabled="true">8765</port>
      <securePort enabled="false">443</securePort>
      <countryId>1</countryId>
      <dataCenterInfo class="com.netflix.appinfo.InstanceInfo$DefaultDataCenterInfo">
        <name>MyOwn</name>
      </dataCenterInfo>
      <leaseInfo>
        <renewalIntervalInSecs>30</renewalIntervalInSecs>
        <durationInSecs>90</durationInSecs>
        <registrationTimestamp>1502197927458</registrationTimestamp>
        <lastRenewalTimestamp>1502198527594</lastRenewalTimestamp>
        <evictionTimestamp>0</evictionTimestamp>
        <serviceUpTimestamp>1502197927458</serviceUpTimestamp>
      </leaseInfo>
      <metadata class="java.util.Collections$EmptyMap"/>
      <homePageUrl>http://localhost:8765/</homePageUrl>
      <statusPageUrl>http://localhost:8765/info</statusPageUrl>
      <healthCheckUrl>http://localhost:8765/health</healthCheckUrl>
      <vipAddress>router</vipAddress>
      <secureVipAddress>router</secureVipAddress>
      <isCoordinatingDiscoveryServer>false</isCoordinatingDiscoveryServer>
      <lastUpdatedTimestamp>1502197927458</lastUpdatedTimestamp>
      <lastDirtyTimestamp>1502197825173</lastDirtyTimestamp>
      <actionType>ADDED</actionType>
    </instance>
  </application>
  <application>
    <name>ORDERS</name>
    <instance>
      <instanceId>localhost:ORDERS:8081</instanceId>
      <hostName>localhost</hostName>
      <app>ORDERS</app>
      <ipAddr>10.0.75.1</ipAddr>
      <status>UP</status>
      <overriddenstatus>UNKNOWN</overriddenstatus>
      <port enabled="true">8081</port>
      <securePort enabled="false">443</securePort>
      <countryId>1</countryId>
      <dataCenterInfo class="com.netflix.appinfo.InstanceInfo$DefaultDataCenterInfo">
        <name>MyOwn</name>
      </dataCenterInfo>
      <leaseInfo>
        <renewalIntervalInSecs>30</renewalIntervalInSecs>
        <durationInSecs>90</durationInSecs>
        <registrationTimestamp>1502198168983</registrationTimestamp>
        <lastRenewalTimestamp>1502198528945</lastRenewalTimestamp>
        <evictionTimestamp>0</evictionTimestamp>
        <serviceUpTimestamp>1502198088982</serviceUpTimestamp>
      </leaseInfo>
      <metadata class="java.util.Collections$EmptyMap"/>
      <homePageUrl>http://localhost:8081/</homePageUrl>
      <statusPageUrl>http://localhost:8081/info</statusPageUrl>
      <healthCheckUrl>http://localhost:8081/health</healthCheckUrl>
      <vipAddress>ORDERS</vipAddress>
      <secureVipAddress>ORDERS</secureVipAddress>
      <isCoordinatingDiscoveryServer>false</isCoordinatingDiscoveryServer>
      <lastUpdatedTimestamp>1502198168983</lastUpdatedTimestamp>
      <lastDirtyTimestamp>1502198168956</lastDirtyTimestamp>
      <actionType>ADDED</actionType>
    </instance>
  </application>
  <application>
    <name>FRONTEND</name>
    <instance>
      <instanceId>32e1ed7e75ba:8080</instanceId>
      <hostName>32e1ed7e75ba</hostName>
      <app>FRONTEND</app>
      <ipAddr>172.17.0.3</ipAddr>
      <status>UP</status>
      <overriddenstatus>UNKNOWN</overriddenstatus>
      <port enabled="true">8080</port>
      <securePort enabled="false">7002</securePort>
      <countryId>1</countryId>
      <dataCenterInfo class="com.netflix.appinfo.InstanceInfo$DefaultDataCenterInfo">
        <name>MyOwn</name>
      </dataCenterInfo>
      <leaseInfo>
        <renewalIntervalInSecs>30</renewalIntervalInSecs>
        <durationInSecs>90</durationInSecs>
        <registrationTimestamp>1502197928887</registrationTimestamp>
        <lastRenewalTimestamp>1502198529372</lastRenewalTimestamp>
        <evictionTimestamp>0</evictionTimestamp>
        <serviceUpTimestamp>1502197928887</serviceUpTimestamp>
      </leaseInfo>
      <metadata class="java.util.Collections$EmptyMap"/>
      <homePageUrl>http://32e1ed7e75ba:8080</homePageUrl>
      <statusPageUrl>http://32e1ed7e75ba:8080/info</statusPageUrl>
      <healthCheckUrl>http://32e1ed7e75ba:8080/health</healthCheckUrl>
      <vipAddress>true</vipAddress>
      <isCoordinatingDiscoveryServer>false</isCoordinatingDiscoveryServer>
      <lastUpdatedTimestamp>1502197928887</lastUpdatedTimestamp>
      <lastDirtyTimestamp>1502197928886</lastDirtyTimestamp>
      <actionType>ADDED</actionType>
    </instance>
  </application>
</applications>

然后我问我的ROUTER,它知道哪些(使用来自https://spring.io/guides/gs/service-registration-and-discovery/的ServiceInstanceRestController)它说2-ROUTER和ORDER,但没有FRONTEND。

有谁知道可能是什么原因?

正如一个提示,WEBFRONT应用程序是一个带有eureka插件的nodejs应用程序。 ROUTER和ORDERS都是靴子。 显然FRONTEND正确注册,尤里卡认为它是UP。我对ORDERS和FRONTEND的eureka XML输出进行了逐行比较,并没有看到真正的任何关键差异......

1 个答案:

答案 0 :(得分:1)

我找到的一件事是前端服务的cleancc <- read.table(text = " 'Education' 'Status' 'College' 'Default' 'College' 'No Default' 'HS' 'Default' 'PHD' 'No Default' 'HS' 'No Default' 'College' 'No Default'", header = T, stringsAsFactors = F) library(dplyr) cleancc %>% group_by(Education) %>% summarize(Def = sum(Status == 'Default'), NDef = sum(Status == 'No Default'), DefRate = Def / (Def + NDef)) 字段vipAddress,但我认为在您的情况下应该是trueFRONTEND。因为幕后frontend使用EurekaDiscoveryClient函数(source in the spring-cloud-netflix-eureka-client project)来查询com.netflix.discovery.EurekaClient getInstancesByVipAddress(String,bool)的可用服务。

更改后,您应该在路由器服务vipAddress路径的响应中看到该服务。