Spring Cloud 2.2.2 源码之四十八nacos客户端触发服务刷新原理二

服务获取和刷新的流程图

Spring Cloud 2.2.2 源码之四十八nacos客户端触发服务刷新原理二

NacosServerList实例化

继续上篇,接下来就是实例化到这里了:
Spring Cloud 2.2.2 源码之四十八nacos客户端触发服务刷新原理二
config就是上篇最后实例化的DefaultClientConfigImplclientName被赋值为服务名。
Spring Cloud 2.2.2 源码之四十八nacos客户端触发服务刷新原理二
initWithNiwsConfig刚好可以取到:
Spring Cloud 2.2.2 源码之四十八nacos客户端触发服务刷新原理二

ZoneAwareLoadBalancer实例化

可以看到这里注入的就是NacosServerList,因为NacosServerList实现了ServerList接口,容器里唯一一个ServerList的实例,刚好注入。
Spring Cloud 2.2.2 源码之四十八nacos客户端触发服务刷新原理二
Spring Cloud 2.2.2 源码之四十八nacos客户端触发服务刷新原理二

Spring Cloud 2.2.2 源码之四十八nacos客户端触发服务刷新原理二
然后在初始化方法restOfInitupdateListOfServers中调用的就是NacosServerListgetUpdatedListOfServers方法,因此这个更新服务列表的任务成功的被nacos接管了:
Spring Cloud 2.2.2 源码之四十八nacos客户端触发服务刷新原理二

NacosServerList的getUpdatedListOfServers

内部是调用NacosDiscoveryProperties中的NamingServiceselectInstances方法,所以一开始看到NacosServerList创建的时候怎么就只传了一个NacosDiscoveryProperties,这个是配置,能干嘛呢,其实他里面有个NamingService实例,可是功能强大啊:
Spring Cloud 2.2.2 源码之四十八nacos客户端触发服务刷新原理二
后面说他是怎么更新的,当然此时ZoneAwareLoadBalancer也开了一个定时任务30秒一次的调用updateListOfServers方法,也就是调用getUpdatedListOfServers,但是其实他只是获取了一次,后面就不会重复获取,更新的任务其实是交给HostReactor中的UpdateTask任务了,为什么这么说呢,后面讲。

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