Alternatives to the Native Netflix EurekaClient
您无需使用原始Netflix EurekaClient。此外,在某种包装后面使用它通常更方便。Spring Cloud通过逻辑Eureka服务标识符(VIP)而不是物理URL支持Feign(REST客户端构建器)和Spring RestTemplate。要使用固定的物理服务器列表配置功能区,可以将<client> .ribbon.listOfServers设置为以逗号分隔的物理地址(或主机名)列表,其中<client>是客户端的ID。
您还可以使用org.springframework.cloud.client.discovery.DiscoveryClient,它为发现客户端提供简单的API(不特定于Netflix),如以下示例所示:
@Autowired
private DiscoveryClient discoveryClient;
public String serviceUrl() {
List<ServiceInstance> list = discoveryClient.getInstances("STORES");
if (list != null && list.size() > 0 ) {
return list.get(0).getUri();
}
return null;
}
Why Is It so Slow to Register a Service?
作为实例还涉及到注册表的定期心跳(通过客户端的serviceUrl),默认持续时间为30秒。在实例,服务器和客户端在其本地缓存中都具有相同的元数据之前,客户端无法发现服务(因此可能需要3次心跳)。您可以通过设置eureka.instance.leaseRenewalIntervalInSeconds来更改周期。将其设置为小于30的值会加快使客户端连接到其他服务的过程。在生产中,最好坚持使用默认值,因为服务器中的内部计算会对租赁续订期做出假设。
Zones
如果已将Eureka客户端部署到多个区域,则可能希望这些客户端在尝试另一个区域中的服务之前使用同一区域内的服务。要进行此设置,您需要正确配置Eureka客户端。
首先,您需要确保将Eureka服务器部署到每个区域,并确保它们彼此对等。有关详细信息,请参阅有关区域和区域的部分。
接下来,您需要告诉Eureka您的服务所在的区域。您可以使用metadataMap属性来执行此操作。例如,如果将服务1部署到区域1和区域2,则需要在服务1中设置以下Eureka属性:
Service 1 in Zone 1
eureka.instance.metadataMap.zone = zone1
eureka.client.preferSameZoneEureka = true
Service 1 in Zone 2
eureka.instance.metadataMap.zone = zone2
eureka.client.preferSameZoneEureka = true