今天这篇文章来介绍一下Nacos配置中心的原理之一:长轮询机制的应用
为方便理解与表达,这里把 Nacos 控制台和 Nacos 注册中心称为 Nacos 服务器(就是 web 界面那个),我们编写的业务服务称为 Nacso 客户端;
Nacos 动态监听的长轮询机制原理图,本篇将围绕这张图剖析长轮询定时机制的原理:

ConfigService 是 Nacos 客户端提供的用于访问实现配置中心基本操作的类型,我们将从 ConfigService 的实例化开始长轮询定时机制的源码之旅;
1. 客户端的长轮询定时机制
我们从
NacosPropertySourceLocator.locate()开始【断点步入】:
1.1 利用反射机制实例化 NacosConfigService 对象
客户端的长轮询定时任务是在
NacosFactory.createConfigService() 方法中,构建 ConfigService 对象是实例时启动的,我们接着 1.1 处的源码;
进入
NacosFactory.createConfigService():
public static ConfigService createConfigService(Properties properties) throws NacosException { //【断点步入】创建 ConfigService return ConfigFactory.createConfigService(properties);}
进入
ConfigFactory.createConfigService(),发现其使用反射机制实例化 NacosConfigService 对象;

1.2 NacosConfigService 的构造方法里启动长轮询定时任务
进入
NacosConfigService.NacosConfigService() 构造方法,里面设置了一些跟远程任务相关的属性;

1.2.1 初始化 HttpAgent
MetricsHttpAgent 类的设计如下:

ServerHttpAgent 类的设计如下:

1.2.2 初始化 ClientWorker
进入 ClientWorker.ClientWorker() 构造方法,主要是创建了两个定时调度的线程池,并启动一个定时任务;

进入
ClientWorker.checkConfigInfo(),每隔 10s 检查一次配置是否发生变化;
- cacheMap:是一个 AtomicReference<Map<String, CacheData>> 对象,用来存储监听变更的缓存集合,key 是根据 datalD/group/tenant(租户)拼接的值。Value 是对应的存储在 Nacos 服务器上的配置文件的内容;
- 长轮询任务拆分:默认情况下,每个长轮询 LongPollingRunnable 任务处理3000个监听配置集。如果超过3000个,则需要启动多个 LongPollingRunnable 去执行;

1.3 检查配置变更,读取变更配置 LongPollingRunnable.run()
因为我们没有这么多配置项,debug 不进去,所以直接找到 LongPollingRunnable.run() 方法,该方法的主要逻辑是:
根据 taskld 对 cacheMap 进行数据分割;
再通过checkLoc

本文深入探讨了Nacos配置中心的长轮询机制,从客户端和服务器端两个角度阐述。客户端通过反射机制实例化NacosConfigService,启动长轮询定时任务,检查并读取配置变更。服务器端接收请求,执行长轮询定时任务,并在配置变更时通过事件监听机制响应客户端。整个过程涉及HttpAgent、ClientWorker和定时调度等关键组件。
最低0.47元/天 解锁文章
389

被折叠的 条评论
为什么被折叠?



