nacos配置中心源码分析——长轮询动态刷新

目录

发布配置

通知客户端配置变化

长轮询

客户端长轮询

服务端长轮询 

总结


所谓动态刷新是指nacos用户交互页面发布或者更新配置,在spring cloud微服务中是如何感知的,并且如何动态刷新配置?

用户操作nacos UI交互页面发布配置请求,请求url:config/v1/cs/configs。

发布配置

请求来到nacos服务端的ConfigController.publishConfig()方法,由于没有选择beta发布,所以betaIp为空,tag好像是跟容器部署有关。所以直接执行如下if里面两个核心方法:persistService.insertOrUpdate()和ConfigChangePublisher.notifyConfigChange(),

在insertOrUpdate()方法有一个蛮有意思的小窍门来区分是新增配置还是更新配置,先直接新增配置 ,如果失败抛出特定异常表示唯一约束冲突,说明数据已经存在,捕获异常后直接更新数据。

在addConfigInfo()和udateConfigInfo()中分别进行新增和更新数据:

数据库中数据更新完成完成后,回到ConfigChangePublisher.notifyConfigChange()中,它发布了ConfigDataChangeEvent事件,

在AsyncNotifyService中已经注册了该事件的订阅者,执行ConfigExecutor.executeAsyncNotify()方法创建线程池并提交异步任务AsyncTask();

进入AsyncTask,向自己发送http请求,请求连接在代码中是写死了为:/nacos/v1/cs/communication/dataChange,注意这里传递了回调的执行类AsyncNotifyCallBack,请求结束后会回调它的onReceive(),

通知客户端配置变化

请求来到CommunicationController.notifyConfigInfo(),他直接调用dump()方法向TaskManager添加异步任务

上篇博客已经分析了TaskManager及其父类Na

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Nacos配置中心控制台的源码分析可以帮助我们深入理解其实现细节和工作原理。以下是一个大致的源码分析过程: 1. 入口类分析:首先,我们需要找到Nacos配置中心控制台的入口类。该类通常是一个Spring Boot应用的启动类,负责初始化和启动整个应用。我们可以查找包含main方法的类,或者在启动脚本中找到应用的入口点。 2. 依赖分析:接下来,我们需要分析应用所依赖的第三方库和框架。查看应用的pom.xml文件或者build.gradle文件,可以获取到所依赖的各个库和对应版本。这些依赖通常包括Spring框架、Nacos客户端等。 3. 配置加载与解析:Nacos配置中心控制台需要加载和解析配置,包括数据库配置、Nacos服务地址配置等。我们可以查找相关的配置文件或者代码片段,了解配置的加载和解析过程。 4. 控制器与路由:控制台通常提供了一些Web接口供前端调用。我们可以查找控制器类,分析其中的方法和注解,了解各个接口的功能和路由规则。 5. 页面模板与前端交互:配置中心控制台通常包含一些页面模板和与前端的交互逻辑。我们可以查找相关的HTML、CSS和JavaScript文件,分析页面的结构和交互逻辑。 6. 调用Nacos API:控制台需要与Nacos服务器进行通信,调用Nacos的API获取和修改配置信息。我们可以查找相关的API调用,了解控制台是如何与Nacos服务器进行通信的。 通过以上分析,我们可以逐步了解Nacos配置中心控制台的实现细节和工作原理。需要注意的是,具体的源码分析过程会因项目结构和代码风格而有所不同。以上只是一个大致的指导,具体分析还需根据实际情况来进行。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值