2023-09-15  阅读(129)
原文作者:王伟王胖胖 原文地址: https://blog.csdn.net/wangwei19871103/article/details/105798539

服务获取和刷新的流程图

202309152317403751.png

NacosServerList实例化

继续上篇,接下来就是实例化到这里了:

202309152317413832.png
config就是上篇最后实例化的DefaultClientConfigImplclientName被赋值为服务名。

202309152317420263.png
initWithNiwsConfig刚好可以取到:

202309152317425684.png

ZoneAwareLoadBalancer实例化

可以看到这里注入的就是NacosServerList,因为NacosServerList实现了ServerList接口,容器里唯一一个ServerList的实例,刚好注入。

202309152317429695.png

202309152317436756.png

202309152317441587.png
然后在初始化方法restOfInitupdateListOfServers中调用的就是NacosServerListgetUpdatedListOfServers方法,因此这个更新服务列表的任务成功的被nacos接管了:

202309152317446948.png

NacosServerList的getUpdatedListOfServers

内部是调用NacosDiscoveryProperties中的NamingServiceselectInstances方法,所以一开始看到NacosServerList创建的时候怎么就只传了一个NacosDiscoveryProperties,这个是配置,能干嘛呢,其实他里面有个NamingService实例,可是功能强大啊:

202309152317453719.png
后面说他是怎么更新的,当然此时ZoneAwareLoadBalancer也开了一个定时任务30秒一次的调用updateListOfServers方法,也就是调用getUpdatedListOfServers,但是其实他只是获取了一次,后面就不会重复获取,更新的任务其实是交给HostReactor中的UpdateTask任务了,为什么这么说呢,后面讲。

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

阅读全文
  • 点赞