1.Nacos服务端源码分析(四): 拉取服务信息
2.Nacos源码分析-集群间临时实例数据的前前端一致性同步
3.Nacos 配置中心源码 | 京东物流技术团队
4.Nacos知识分享:4.源码编译启动遇到的坑
5.手撕Nacos源码剖析,建议收藏
6.Nacos 注册服务源码分析
Nacos服务端源码分析(四): 拉取服务信息
本文深入解析Nacos服务端源码,端源特别关注服务信息的前前端索尼源码透传主动拉取机制。主动拉取服务信息的端源URL为:/alibaba/nacos/releases/tag/2.1.1。解压源码后,前前端TH1750实验源码使用IDEA打开项目。端源丽江古城到泸沽湖源码若在com.alibaba.nacos.consistency.entity类处遇到报红错误,前前端通过编译整个项目解决此问题。端源
解决报红后,前前端使用终端在nacos-2.1.1目录下执行编译操作。端源
定位至console项目中的前前端Nacos启动类,并配置VM options参数,端源设置为单机模式启动。前前端java校园兼职系统源码
成功启动后,端源控制台应显示项目启动成功的前前端医疗急救小程序源码信息。
执行命令请求http://.0.0.1:/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åè®®ååéç¥å®¢æ·ç«¯è¿æ¬¡æå¡å¼å¸¸åå¨ã