服务获取和刷新的流程图

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任务了,为什么这么说呢,后面讲。

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

相关文章:

  • 2021-11-14
  • 2021-10-07
  • 2021-07-13
  • 2021-11-20
  • 2021-08-14
  • 2021-08-21
  • 2021-07-13
  • 2023-02-09
猜你喜欢
  • 2021-12-28
  • 2021-07-28
  • 2021-11-03
  • 2021-04-18
  • 2021-10-18
  • 2021-05-18
  • 2021-06-12
相关资源
相似解决方案