美文网首页Spring
Spring Cloud注册发现:Eureka

Spring Cloud注册发现:Eureka

作者: 王勇1024 | 来源:发表于2019-07-14 11:58 被阅读0次

    Eureka简介

    Eureka是Netflix开发的服务发现框架,本身是一个基于REST的服务,主要用于定位运行在AWS域中的中间层服务,以达到负载均衡和中间层服务故障转移的目的。SpringCloud将它集成在其子项目spring-cloud-netflix中,以实现SpringCloud的服务发现功能。

    Eureka包含两个组件:Eureka Server和Eureka Client,其中Eureka Client又可以分为Eureka Provider和Eureka Consumer。

    Eureka Server

    • 服务端-没有存储,内存保持,每服务实例需要发送心跳去续约
    • 客户端-在内存中缓存着eureka的注册信息,因此不必每请求到eureka查找服务
    • eureka之间会做注册服务同步,从而保证状态一致,客户端只需访问一个eureka

    Service Provider

    • 会向Eureka Server做Register(服务注册)、Renew(服务续约)、Cancel(服务下线)等操作

    Service Consumer

    • 会从Eureka Server获取注册服务列表,并消费服务

    注册发现

    Eureka注册发现

    Eureka Server提供服务注册服务,各个节点启动后,会在Eureka Server中进行注册,这样EurekaServer中的服务注册表中将会存储所有可用服务节点的信息,服务节点的信息可以在界面中直观的看到。

    Eureka Client是一个Java客户端,用于简化与Eureka Server的交互,客户端同时也就是一个内置的、使用轮询(round-robin)负载算法的负载均衡器。

    服务心跳(renew)

    服务心跳

    在应用启动后,将会向Eureka Server发送心跳,默认周期为30秒,如果Eureka Server在多个心跳周期内没有接收到某个节点的心跳,Eureka Server将会从服务注册表中把这个服务节点移除(默认90秒)。

    服务实例会通过心跳(eureka.instance.lease-renewal-interval-in-seconds定义心跳的频率,默认值为30s)续约的方式向Eureka Server定时更新自己的状态。Eureka Server收到心跳后,会通知集群里的其它Eureka Server更新此实例的状态。Service Provider/Service Consumer也会定时更新缓存的实例信息。

    Eureka Server间数据同步

    Eureka Server间数据同步

    为了解决Eureka Server单点的问题,我们可以启动多个Eureka Server注册中心,并让多个Eureka Server注册中心相互注册,这样可以实现Eureka Server注册中心集群。这是一种去中心化的架构中,各个节点是平等的,每个节点都保存完整实例注册服务的信息。

    Eureka Server 集群不区分主从节点或者 Primary & Secondary 节点,所有节点相同角色( 也就是没有角色 ),完全对等。
    Eureka Client 可以向任意 Eureka Client 发起任意读写操作,Eureka Server 将操作复制到另外的 Eureka Server 以达到最终一致性。注意,Eureka Server 是选择了 AP 的组件。

    Eureka Server之间通过复制的方式完成数据的同步,Eureka还提供了客户端缓存机制,即使所有的Eureka Server都挂掉,客户端依然可以利用缓存中的信息消费其他服务的API。综上,Eureka通过心跳检查、客户端缓存等机制,确保了系统的高可用性、灵活性和可伸缩性。

    自我保护模式

    自我保护模式

    如果Eureka Server最近1分钟收到renew的次数小于阈值(即预期的最小值),则会触发自我保护模式(如上图所示,在Eureka Server首页可以看到一排红色的警告信息),此时Eureka Server此时会认为这是网络问题,它不会注销任何过期的实例。等到最近收到renew的次数大于阈值后,则Eureka Server退出自我保护模式。

    自我保护模式阈值计算:

    每个instance的预期心跳数目 = 60/每个instance的心跳间隔秒数
    阈值 = 所有注册到服务的instance的数量的预期心跳之和 *自我保护系数
    以上的参数都可配置的:

    instance的心跳间隔秒数:eureka.instance.lease-renewal-interval-in-seconds
    自我保护系数:eureka.server.renewal-percent-threshold
    如果我们的实例比较少且是内部网络时,推荐关掉此选项。我们也可以通过eureka.server.enable-self-preservation = false来禁用自我保护系数

    参考文档

    Spring cloud系列五 Eureka 之集群同步、自我保护模式以及实例注册、心跳、下线
    注册中心 Eureka 源码解析 —— Eureka-Server 集群同步

    相关文章

      网友评论

        本文标题:Spring Cloud注册发现:Eureka

        本文链接:https://www.haomeiwen.com/subject/ckybkctx.html