ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

Spring Cloud Netflix简介 (三)

2019-03-23 16:55:40  阅读:279  来源: 互联网

标签:Netflix Spring list eureka 区域 Eureka Cloud 客户端


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

标签:Netflix,Spring,list,eureka,区域,Eureka,Cloud,客户端
来源: https://blog.csdn.net/u013702678/article/details/88762638

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有