服务获取和刷新的流程图
NacosServerList实例化
继续上篇,接下来就是实例化到这里了:
config
就是上篇最后实例化的DefaultClientConfigImpl
,clientName
被赋值为服务名。
initWithNiwsConfig
刚好可以取到:
ZoneAwareLoadBalancer实例化
可以看到这里注入的就是NacosServerList,因为NacosServerList
实现了ServerList
接口,容器里唯一一个ServerList
的实例,刚好注入。
然后在初始化方法restOfInit
的updateListOfServers
中调用的就是NacosServerList
的getUpdatedListOfServers
方法,因此这个更新服务列表的任务成功的被nacos
接管了:
NacosServerList的getUpdatedListOfServers
内部是调用NacosDiscoveryProperties
中的NamingService
的selectInstances
方法,所以一开始看到NacosServerList
创建的时候怎么就只传了一个NacosDiscoveryProperties
,这个是配置,能干嘛呢,其实他里面有个NamingService
实例,可是功能强大啊:
后面说他是怎么更新的,当然此时ZoneAwareLoadBalancer
也开了一个定时任务30秒一次的调用updateListOfServers
方法,也就是调用getUpdatedListOfServers
,但是其实他只是获取了一次,后面就不会重复获取,更新的任务其实是交给HostReactor
中的UpdateTask
任务了,为什么这么说呢,后面讲。
好了,今天就到这里了,希望对学习理解有帮助,大神看见勿喷,仅为自己的学习理解,能力有限,请多包涵。