7

我正在尝试使用基于 DNS 的 EIP 配置在 aws 上设置 eureka 集群,如https://github.com/Netflix/eureka/wiki/Configuring-Eureka-in-AWS-Cloud中所述

一切似乎都正常,但尤里卡仪表板坚持认为尤里卡实例不可用。我现在想知道这是否只是一个 ui 问题(我认为是这样),或者我是否遗漏了一些东西。

据我了解仪表板中的“不可用副本”逻辑,这是因为 eureka 正在比较注册主机名和副本主机名。实例在发现客户端使用其内部 VPC ip 注册,但在寻找副本对等点时使用其 EIP 注册(很奇怪,在尤里卡日志中,我可以在内部看到它们也在使用内部 VPC ip)。

问题是:这只是一些我不应该担心的装饰性 ui 问题,还是因为配置错误而等待介入的更大问题?如果它只是一个 ui 的东西:我能以某种方式“修复”它吗?

在此处输入图像描述

编辑:

也许相关https://github.com/spring-cloud/spring-cloud-netflix/issues/102#issuecomment-74446709

4

1 回答 1

13

在相关 github 问题中@rozhok 的帮助下,我现在有了一个可行的解决方案。如果有人面临同样的问题,这就是我所做的:

应用程序.yml

eureka:
  datacenter: cloud
  client:
    eurekaServerDNSName: your.dns.name
    eurekaServerPort: 8761
    eurekaServerURLContext: eureka
    region: eu-west-1
    registerWithEureka: true
    fetchRegistry: true
    useDnsForFetchingServiceUrls: true
  server:
    waitTimeInMsWhenSyncEmpty: 0
    enableSelfPreservation: true

尤里卡服务器

@SpringBootApplication
@EnableEurekaServer
@EnableDiscoveryClient
public class EurekaServer {

    @Value("${server.port:8761}") 
    private int port;

    public static void main(String[] args) {
        SpringApplication.run(EurekaServer.class, args);
    }

    @Bean
    @Autowired
    public EurekaInstanceConfigBean eurekaInstanceConfigBean(InetUtils inetUtils) {
      EurekaInstanceConfigBean config = new EurekaInstanceConfigBean(inetUtils);
      AmazonInfo info = AmazonInfo.Builder.newBuilder().autoBuild("eureka");

      // Don't use spring cloud's hostname here. 
      // See comment below by Michal
      config.setHostname(
          info.get(AmazonInfo.MetaDataKey.publicHostname));

      config.setIpAddress(info.get(AmazonInfo.MetaDataKey.publicIpv4));
      config.setNonSecurePort(port);
      config.setDataCenterInfo(info);
      return config;
    }

}

使用该配置,每个 eureka 服务器仅将其他服务器视为可用副本:

在此处输入图像描述

于 2016-04-07T15:42:10.717 回答