皮皮网
皮皮网

【信息公司源码】【用xshell上传源码】【egret 塔防源码】手写nacos源码_手写原生代码

来源:防滑涂料指标源码 发表时间:2024-11-26 21:02:18

1.Nacos 源码环境搭建
2.Nacos服务端源码分析(四): 拉取服务信息
3.手撕Nacos源码剖析,手写生代建议收藏
4.Nacos 注册服务源码分析
5.Nacos知识分享:4.源码编译启动遇到的码手码坑
6.Nacos系列创建ConfigService实例源码分析

手写nacos源码_手写原生代码

Nacos 源码环境搭建

       探索Nacos源码搭建环境的过程,通过深入分析服务注册与发现机制,写原本文重点阐述了本地部署Nacos源码的手写生代详细步骤。Nacos版本采用2.1.1。码手码

       从github上获取Nacos源码,写原信息公司源码下载指定版本的手写生代源码包,地址位于/alibaba/nacos/releases/tag/2.1.1。码手码

       解压源码后,写原使用IDEA打开项目。手写生代若在com.alibaba.nacos.consistency.entity类处遇到报红错误,码手码通过编译整个项目解决此问题。写原

       解决报红后,手写生代使用终端在nacos-2.1.1目录下执行编译操作。码手码

       定位至console项目中的写原Nacos启动类,并配置VM options参数,设置为单机模式启动。

       成功启动后,控制台应显示项目启动成功的信息。

       执行命令请求http://.0.0.1:/nacos,同时观察控制台输出,用xshell上传源码验证部署过程的正确性。

Nacos服务端源码分析(四): 拉取服务信息

       本文深入解析Nacos服务端源码,特别关注服务信息的主动拉取机制。主动拉取服务信息的URL为:https://localhost:/nacos/v1/ns/instance/list。依据此URL,Nacos服务端会处理请求,具体操作如下:

       首先,获取并校验参数,随后调用`getInstanceOperator().listInstance()`函数。

       `getInstanceOperator().listInstance()`执行流程如下:

       通过`createIpPortClientIfAbsent()`确保client管理正常,若未存在则加入`clients`。

       调用`clientOperationService.subscribeService()`发布事件`ClientOperationEvent.ClientSubscribeServiceEvent`,进行服务订阅。

       调用`ServiceUtil.selectInstancesWithHealthyProtection()`获取serviceInfo,包括实例列表。

       分析各个方法的内部逻辑:

       `createIpPortClientIfAbsent()`:若`clientManager`中不存在指定`clientId`,则加入`clients`。

       `clientOperationService.subscribeService()`:发布事件`ClientOperationEvent.ClientSubscribeServiceEvent`,涉及订阅操作,将服务作为key,egret 塔防源码保存在`subscriberIndexes`中。首次添加时,会触发事件`ServiceEvent.ServiceSubscribedEvent`,将服务信息推送至订阅客户端。

       `ServiceUtil.selectInstancesWithHealthyProtection()`:整合相关信息,筛选健康的服务实例,最终返回。

       总结以上分析,Nacos服务端主动拉取服务信息的过程涉及参数验证、事件发布、实例筛选等关键步骤。这一机制确保了服务信息的及时更新与准确传递。

       下篇文章预告:探讨Nacos之Distro协议的理论基础。

手撕Nacos源码剖析,建议收藏

       Nacos源码剖析

       深入学习Nacos,解析源码,重点关注以下两点:

       源码环境搭建

       从官方项目克隆Nacos源码,检出1.4.1版本,导入IDEA。

       在本地MySQL中创建nacos-config数据库,php餐厅管理源码执行resources/META-INF/nacos-db.sql脚本创建表。

       修改console模块下的application.properties文件,配置相关参数。

       启动console模块的启动类,非集群模式启动Nacos服务端。

       访问本地Nacos服务:http://localhost:/nacos。

       Nacos客户端功能

       Nacos客户端集成在应用服务内,通过依赖引入实现服务注册、发现、下线及订阅功能。

       客户端核心功能包括服务注册、服务发现、服务下线与服务订阅。

       客户端与服务端交互,主要聚焦服务注册、服务下线、服务发现与服务订阅。

       服务注册

       注册服务时,客户端执行定时任务设置心跳监测,同时向服务端注册服务。dwr.jar源码

       服务注册中,远程请求通过NacosRestTemplate封装,调用callServer()执行。

       服务发现

       通过NamingService.getAllInstances()方法实现服务发现。

       获取服务信息首先从缓存查找,若无数据,则向Nacos服务端请求更新。

       服务下线

       服务下线操作简化,主要取消心跳检测与服务下线接口请求。

       服务订阅

       客户端创建线程池,封装监听器,监听指定服务实例信息变化。

       通过NamingService.subscribe()方法实现服务订阅,注册监听器,接收实例信息更新。

Nacos 注册服务源码分析

       Nacos 注册服务源码分析

       首先,从nacos-example样例工程入手,寻找注册服务的关键入口。在NamingExample的main方法中,我们关注的两行代码揭示了整个过程的起点。

       从NamingFactory#createNamingService开始,这个方法通过构造函数创建了一个NacosNamingService。值得注意的是,虽然创建过程看似简单,但构造方法中包含了属性的初始化和处理,这在非Spring项目中尤为重要,通常通过静态代码块或构造方法自行完成。

       真正注册服务的核心在于registerInstance方法。这个方法内部调用了clientProxy.registerService,跟踪这个过程是理解Nacos注册服务的关键。

       进一步追踪NamingService的构造方法,可以看到它内部创建了NamingClientProxyDelegate代理类。这个代理类实际上是设计模式中的代理模式,用于将请求委托给grpcClientProxy或httpClientProxy进行远程调用。

       深入理解后,我们发现grpcClientProxy#registerService是实际执行注册操作的地方。它通过gRpc技术,将客户端的请求发送到服务端,注册成功后,整个注册过程完成。

       接下来,我们关注的是rpcClient#request方法,这里涉及currentConnection的创建和请求过程。currentConnection在RpcClient的start方法中初始化,然后在connectToServer方法中建立连接。

       至于rpc的请求,就是简单地利用已建立的连接和请求Stub发送请求。

       总结来说,Nacos客户端通过NacosNamingService调用代理类,最终通过gRpc技术与服务端进行交互。虽然本文仅阐述了客户端的请求过程,但服务端如何处理这些请求才是Nacos的核心功能。

Nacos知识分享:4.源码编译启动遇到的坑

       获取Nacos源码从Gitee进行,选择2.1.2的标签,创建新分支。

       使用IDEA打开代码,确保使用的是JDK1.8版本以及3.5版本以上的Maven。

       consistency目录下的proto文件需使用特定插件编译为Java代码。

       配置nacos-console和nacos-distribution服务中的application.properties文件以连接自定义的MySQL数据库,确保配置正确。

       在distribution\conf目录中找到mysql-schema.sql文件,确认数据库表结构。

       尝试直接启动nacos-console服务,若出现错误,检查JDK版本、数据库连接信息、数据库版本和vs_redist版本。

       通过命令行启动时,加入-Dnacos.standalone=true -Dnacos.home=D:\MyStudyGiteeCodeReposity\Nacos\distribution参数。

       最终,项目成功启动,通过访问http://localhost:/nacos/index.html,使用默认用户名和密码nacos/nacos进行验证。

Nacos系列创建ConfigService实例源码分析

       在学习Nacos的过程中,我们关注的重点是创建ConfigService实例的实现。Nacos通过NacosFactory的createConfigService方法创建ConfigService实例,这个工厂类是获取各种服务对象的统一入口。

       ConfigService是配置服务接口,负责配置的获取、发布、管理等操作,其核心实现类NacosConfigService。同样,Nacos的命名服务和维护服务也是通过NacosFactory创建实例的,如NamingService用于服务实例的注册与管理,NamingMaintainService则直接与Nacos服务器交互。

       创建ConfigService的具体流程中,首先通过ConfigFactory的createConfigService方法,构造器会进行一些参数校验,并初始化命名空间。例如,校验contextPath属性的合法性,确保其不包含连续的/。然后,会根据用户租户信息、环境变量或配置属性获取namespace值。

       ConfigFilterChainManager和ServerListManager的构造也非常重要,前者管理配置过滤器,后者负责维护服务器列表,能够通过配置属性或动态请求获取最新的服务器信息。当创建ConfigService实例时,还会启动长轮询定时任务,如ClientWorker的executeConfigListen方法,通过ServerHttpAgent进行HTTP请求以获取和管理配置数据。

       总结来说,创建ConfigService实例涉及工厂方法的调用、参数处理、服务实例初始化以及与Nacos服务器的交互。通过本文的深入分析,你将更好地理解Nacos配置服务的初始化过程。

nacos原理

       nacos目前是集成到spring cloud alibaba里去的,也就是在spring cloud的标准之下实现了一些东西,spring cloud自己是有一个接口,叫做ServiceRegistry,也就是服务注册中心的概念,nacos中有一个它的实现类NacosServiceRegistry,实现了register、deregister、close、setStatus、getStatus之类的方法。

        自动装配是一个spring boot的一个概念,自动装配的意思,其实就是说系统启动的时候,自动装配机制会运行,实现一些系统的初始化,自动运行,也就是系统启动时自动去调用NacosServiceRegistry的register方法去进行服务注册。而且除了注册之外,还会通过schedule线程池去提交一个定时调度任务,源码如下:

        this.exeutorService.schedule(new BeatReactor.BeatTask(beatInfo), beatInfo.getPeriod(), TimeUnit.MILLISECONDS),这就是一个心跳机制,定时发送心跳给nacos server。

        然后会访问nacos server的open api,其实就是http接口,他有一个接口:http://...:/nacos/v1/ns/instance?serviceName=xx&ip=xx&port=xx,这么一个东西,也没什么特别的,这里就是访问注册接口罢了

        nacos server那里是基于一个ConcurrentHashMap作为注册表来放服务信息的,直接会构造一个Service放到map里,然后对Service去addInstance添加一个实例,本质里面就是在维护信息,同时还会建立定时检查实例心跳的机制。最后还会基于一致性协议,比如说raft协议,去把注册同步给其他节点。

        服务发现的本质其实也是nacos server上的一个http接口,就是:http://...:/nacos/v1/ns/instance/list?serviceName=xx,就这么一个接口,然后就会启动定时任务,每隔s拉取一次最新的实例列表,然后服务端还会监听他服务的状态,有异常就会基于UDP协议反向通知客户端这次服务异常变动。

相关栏目:休闲