大致流程图
剔除任务
这个剔除的任务在初始化的时候就开定时器运行啦。
主要是AbstractInstanceRegistry
的evict
方法。
AbstractInstanceRegistry的evict
首先遍历所有的实例,看是否有过期的,有的话就放入一个集合:
进行服务下线
删除租约实例。
缓存失效:
更新每分钟续约的阈值,这个涉及到自我保护机制的开启:
自我保护机制
PeerAwareInstanceRegistryImpl
的isLeaseExpirationEnabled
,如果自我保护模式机制没开的话,就返回true
,就会继续剔除心跳超时的实例,如果开启的话会进行判断,如果每分钟续约的大于一个阈值的话,就不会去进行剔除,直接返回了。阈值就是续约率大于0.85
就开启自我保护机制,然后不会暂时不会剔除超时实例。
阈值:
如何进行页面提示
低于阈值的时候会进行判断,符合条件就进行保护机制信息打印:
这个跟模型渲染相关:
navbar.ftlh
这个页面里有相关信息打印条件:
刷新页面的时候根据条件打印信息:
好了,剔除和自我保护机制大致了解了,其实保护机制就是一种乐观的举动,如果发现续约率还不错的,有不续约的可能是网络的问题,不会马上剔除,可能后面会来续上,就报一个警告吧,具体的详细细节还是得自己看。
好了,今天就到这里了,希望对学习理解有帮助,大神看见勿喷,仅为自己的学习理解,能力有限,请多包涵。