大致流程图

Spring Cloud 2.2.2 源码之十一Eureka服务处理剔除

剔除任务

这个剔除的任务在初始化的时候就开定时器运行啦。
Spring Cloud 2.2.2 源码之十一Eureka服务处理剔除
主要是AbstractInstanceRegistryevict方法。
Spring Cloud 2.2.2 源码之十一Eureka服务处理剔除

AbstractInstanceRegistry的evict

首先遍历所有的实例,看是否有过期的,有的话就放入一个集合:
Spring Cloud 2.2.2 源码之十一Eureka服务处理剔除

进行服务下线

Spring Cloud 2.2.2 源码之十一Eureka服务处理剔除
删除租约实例。
Spring Cloud 2.2.2 源码之十一Eureka服务处理剔除
缓存失效:
Spring Cloud 2.2.2 源码之十一Eureka服务处理剔除
更新每分钟续约的阈值,这个涉及到自我保护机制的开启:
Spring Cloud 2.2.2 源码之十一Eureka服务处理剔除

自我保护机制

PeerAwareInstanceRegistryImplisLeaseExpirationEnabled,如果自我保护模式机制没开的话,就返回true,就会继续剔除心跳超时的实例,如果开启的话会进行判断,如果每分钟续约的大于一个阈值的话,就不会去进行剔除,直接返回了。阈值就是续约率大于0.85就开启自我保护机制,然后不会暂时不会剔除超时实例。
Spring Cloud 2.2.2 源码之十一Eureka服务处理剔除
阈值:
Spring Cloud 2.2.2 源码之十一Eureka服务处理剔除

如何进行页面提示

低于阈值的时候会进行判断,符合条件就进行保护机制信息打印:
Spring Cloud 2.2.2 源码之十一Eureka服务处理剔除
这个跟模型渲染相关:
Spring Cloud 2.2.2 源码之十一Eureka服务处理剔除
navbar.ftlh这个页面里有相关信息打印条件:
Spring Cloud 2.2.2 源码之十一Eureka服务处理剔除
刷新页面的时候根据条件打印信息:
Spring Cloud 2.2.2 源码之十一Eureka服务处理剔除

好了,剔除和自我保护机制大致了解了,其实保护机制就是一种乐观的举动,如果发现续约率还不错的,有不续约的可能是网络的问题,不会马上剔除,可能后面会来续上,就报一个警告吧,具体的详细细节还是得自己看。

好了,今天就到这里了,希望对学习理解有帮助,大神看见勿喷,仅为自己的学习理解,能力有限,请多包涵。

相关文章: