9、Nacos服务注册服务端源码分析(总结篇)

本文收录于专栏 Nacos 中 。

文章目录


前言

前边几篇文章我们一起看了Nacos中客户端注册时的服务端相关源码,在各个流程上做了简单梳理。这里我们做一个整体上的总结。

流程

一、接收客户端请求,发布客户端注册事件

  • InstanceRequestHandler接收所有实例注册、注销相关的请求
  • InstanceRequestHandler处理注册请求时,会调用EphemeralClientOperationServiceImpl中的registerInstance方法
    • 将当前封装客户端信息的Service添加到ServiceManager中。ServiceManager中会根据namespace缓存当前客户端Service
    • NotifyCenter发布ClientOperationEvent.ClientRegisterServiceEvent事件

二、处理客户端注册事件

  • ClientServiceIndexesManager中的onEvent处理客户端操作事件
  • 当前事件为客户端注册事件ClientOperationEvent.ClientRegisterServiceEvent时:
    • 发布新事件ServiceEvent.ServiceChangedEvent
  • NamingSubscriberServiceV2Impl中的onEvent处理ServiceEvent.ServiceChangedEvent事件:
    • 当前客户端Service被封装成PushDelayTask添加到延迟任务处理引擎 PushDelayTaskExecuteEngine

三、任务处理引擎

  • 任务处理引擎PushDelayTaskExecuteEngine中含有一个单线程延迟线程池,间隔指定时间去处理缓存的任务ConcurrentHashMap<Object, AbstractDelayTask> tasks
  • 延时线程池处理任务时,会使用任务处理器PushDelayTaskProcessor处理任务
    • 将客户端Service组装成PushExecuteTask,然后使用NamingExecuteTaskDispatcher做任务分发,其实就是将任务添加到另一个任务处理引擎NacosExecuteTaskExecuteEngine
    • 调用NacosExecuteTaskExecuteEngine的添加任务方法addTask时,会将当前任务交由TaskExecuteWorker处理

四、执行任务(PushDelayTask)

  • TaskExecuteWorker继承了Thread,其内部维护了一个BlockingQueue<Runnable> queue,重写的run
    方法会不断去扫描队列,然后执行队列中的任务task.run();
    • 这里我们要注意队列中的数据类型是Runnable,所以从队列中获取任务之后可以直接调用任务的run
      方法
    • 结合前边的流程,那么这里的任务其实是PushExecuteTask,一个也继承了Thread,在重写的run方法中会处理Service推送到订阅者的逻辑。

总结

以上,我们简单梳理了客户端注册到Nacos的大致流程,并且给出了其中一些关键的处理类。在前几篇源码分析的文章中,我们可以看出,客户端注册的流程设计里使用了大量的模版模式 去封装局部逻辑。这使得在简单归纳源码之后,整个注册逻辑在流程上较为清晰可见。同时,Nacos面向事件而封装的NotifyCenter也让人印象深刻。

保持怀疑的眼光去审视时,也要有一颗学徒的心不断汲取优秀的设计思想和实现。

关于Nacos2.X版本使用grpc的相关逻辑,这里不再赘述,网上关于grpc的文章多如牛毛。

enjoy~

相关推荐
czlczl200209251 小时前
告别 try-catch 地狱:Spring Boot 全局异常处理 (GlobalExceptionHandler) 最佳实践
java·spring boot·后端
Goldn.7 小时前
Java核心技术栈全景解析:从Web开发到AI融合
java· spring boot· 微服务· ai· jvm· maven· hibernate
李慕婉学姐8 小时前
【开题答辩过程】以《基于Android的出租车运行监测系统设计与实现》为例,不知道这个选题怎么做的,不知道这个选题怎么开题答辩的可以进来看看
java·后端·vue
m0_740043738 小时前
SpringBoot05-配置文件-热加载/日志框架slf4j/接口文档工具Swagger/Knife4j
java·spring boot·后端·log4j
编织幻境的妖8 小时前
SQL查询连续登录用户方法详解
java·数据库·sql
未若君雅裁9 小时前
JVM面试篇总结
java·jvm·面试
kk哥88999 小时前
C++ 对象 核心介绍
java·jvm·c++
招风的黑耳9 小时前
我用SpringBoot撸了一个智慧水务监控平台
java·spring boot·后端
xunyan62349 小时前
面向对象(下)-接口的理解
java·开发语言
程序员游老板9 小时前
基于SpringBoot3+vue3的爱心陪诊平台
java·spring boot·毕业设计·软件工程·课程设计·信息与通信