Nacos 配置服务客户端源码分析(一)

本文从Nacos客户端源码出发,分析了如何通过ConfigService获取和监听配置信息。首先介绍了NacosConfigService的创建过程,然后详细讲解了获取配置信息的步骤,包括尝试从本地失败转移、服务端拉取和本地快照中获取。最后提到了监听配置的实现,当配置变化时,通过回调机制通知并更新配置。文章还简要提及了SpringCloudAlibabaNacosConfig的配置更新处理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Nacos除了服务注册中心,还集成了配置中心。本篇就从Nacos的配置中心的客户端源码入手。分析Nacos客户端是如何获取到Nacos服务的配置文件的。

分析源码的第一步是找到入口,官方再次给了我们一个注册中心的样例代码,在源码的nacos-example工程中。先看下这部分的代码。

publicstaticvoidmain(String[] args)throws NacosException, InterruptedException {
    StringserverAddr="localhost";
    StringdataId="test";
    Stringgroup="DEFAULT_GROUP";
    Propertiesproperties=newProperties();
    properties.put("serverAddr", serverAddr);
    // 通过工厂模式创建了一个ConfigService服务
    ConfigServiceconfigService= NacosFactory.createConfigService(properties);
    // 获取配置信息
    Stringcontent= configService.getConfig(dataId, group, 5000);
    System.out.println(content);
    // 添加监听器,监听对应dataId,group的配置信息
    configService.addListener(dataId, group, newListener() {
        @Override
        publicvoidreceiveConfigInfo(String configInfo) {
            System.out.println("receive:" + configInfo);
        }
        @Override
        public Executor getExecutor() {
            returnnull;
        }
    });
    // 发布配置信息
    booleanisPublishOk= configService.publishConfig(dataId, group, "content");
    System.out.println(isPublishOk);
    Thread.sleep(3000);
    // 获取配置
    content = configService.getConfig(dataId, group, 5000);
    System.out.println(content);
    // 移除配置
    booleanisRemoveOk= configService.removeConfig(dataId, group);
    System.out.println(isRemoveOk);
    Thread.sleep(3000);
    // 获取配置
    content = configService.getConfig(dataId, group, 5000);
    System.out.println(content);
    Thread.sleep(300000);
}
复制代码

NacosConfigService创建

创建ConfigService实现比较简单,就是通过反射创建了NacosConfigService。只是要注意下创建NacosConfigService时会调用它的构造方法,做一些初始化的操作。

publicNacosConfigService(Properties properties)throws NacosException {
    finalNacosClientPropertiesclientProperties= NacosClientProperties.PROTOTYPE.derive(properties);
    ValidatorUtils.checkInitParam(clientProperties);
    // 初始化Namespace
    initNamespace(clientProperties);
    // 创建了一个配置过滤器链,可以采用SPI扩展机制加载对应的过滤器实现类
    this.configFilterChainManager = newConfigFilterChainManager(clientProperties.asProperties());
    ServerListManagerserverListManager=newServerListManager(clientProperties);
    // 创建了一个服务管理器,内含一个定时轮询线程池,每隔30s拉取一次服务
    serverListManager.start();
    // 创建了一个客户端工作者,包含了一个代理对象
    this.worker = newClientWorker(this.configFilterChainManager, serverListManager, clientProperties);
    // will be deleted in 2.0 later versions
    agent = newServerHttpAgent(serverListManager);
}
复制代码

在下一个篇章将重点介绍一下ClientWorker,这个是个核心,所有和服务端的交互都通过它。因为本篇主要讲解客户端注册的流程框架,先不深入细节。这里只需要知道这里进行了创建。

获取配置信息

创建ConfigService后就可以通过接口获取配置信息了。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值