2023-09-15
原文作者:王伟王胖胖 原文地址: https://blog.csdn.net/wangwei19871103/article/details/105616468

大致流程图

202309152311253761.png

剔除任务

这个剔除的任务在初始化的时候就开定时器运行啦。

202309152311261552.png
主要是AbstractInstanceRegistryevict方法。

202309152311270433.png

AbstractInstanceRegistry的evict

首先遍历所有的实例,看是否有过期的,有的话就放入一个集合:

202309152311278154.png

进行服务下线

202309152311291515.png
删除租约实例。

202309152311298226.png
缓存失效:

202309152311306577.png
更新每分钟续约的阈值,这个涉及到自我保护机制的开启:

202309152311313498.png

自我保护机制

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

202309152311321339.png
阈值:

2023091523113282310.png

如何进行页面提示

低于阈值的时候会进行判断,符合条件就进行保护机制信息打印:

2023091523113324011.png
这个跟模型渲染相关:

2023091523113387412.png
navbar.ftlh这个页面里有相关信息打印条件:

2023091523113472913.png
刷新页面的时候根据条件打印信息:

2023091523113564714.png

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

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

阅读全文