精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

Nacos客戶端服務注冊源碼分析

開發 前端
在此之前,已經寫了十多篇Nacos的文章,感覺Nacos還值得更深入的學習一下。于是萌生了寫一個Nacos源碼系列專欄的文章。

[[411614]]

開篇構想

在此之前,已經寫了十多篇Nacos的文章,感覺Nacos還值得更深入的學習一下。于是萌生了寫一個Nacos源碼系列專欄的文章。

寫作的目標呢,有兩個:第一,能夠系統的學習Nacos知識;第二,能夠基于Nacos學到涉及到的知識點或面;

展現形式呢,也有兩個:第一,單篇足夠簡單且又有價值;第二,發現代碼中的新穎之處;

源碼版本信息

目前在生產實踐中建議大家采用1.4.2版本,但作為技術研究,本系列文章會基于2.0.2版本來僅僅講解。這是兩個跨度比較大的版本,建議大家配合源碼進行學習。

關于源碼拉取,環境搭建部分就不再贅述。下面就開始本篇文章,講解Nacos服務注冊的客戶端部分。

服務注冊信息

講到服務注冊,我們先要了解一下Nacos都會將什么信息傳遞給服務器。直接從Nacos Client項目的NamingTest看起:

  1. Properties properties = new Properties(); 
  2. properties.put(PropertyKeyConst.SERVER_ADDR, "127.0.0.1:8848"); 
  3. properties.put(PropertyKeyConst.USERNAME, "nacos"); 
  4. properties.put(PropertyKeyConst.PASSWORD"nacos"); 
  5.  
  6. Instance instance = new Instance(); 
  7. instance.setIp("1.1.1.1"); 
  8. instance.setPort(800); 
  9. instance.setWeight(2); 
  10. Map<String, String> map = new HashMap<String, String>(); 
  11. map.put("netType""external"); 
  12. map.put("version""2.0"); 
  13. instance.setMetadata(map); 
  14.  
  15. NamingService namingService = NacosFactory.createNamingService(properties); 
  16. namingService.registerInstance("nacos.test.1", instance); 

這是服務注冊的核心所有代碼。僅從此處的代碼分析,可以看出,Nacos注冊服務實例時,包含了兩大類信息:Nacos Server連接信息和實例信息。

Nacos Server連接信息

Nacos Server連接信息,存儲在Properties當中,包含以下信息:

  • Server地址:Nacos服務器地址,屬性的key為serverAddr;
  • 用戶名:連接Nacos服務的用戶名,屬性key為username,默認值為nacos;
  • 密碼:連接Nacos服務的密碼,屬性key為password,默認值為nacos;

實例信息

注冊實例信息用Instance對象承載,注冊的實例信息又分兩部分:實例基礎信息和元數據。

實例基礎信息包括:

  • instanceId:實例的唯一ID;
  • ip:實例IP,提供給消費者進行通信的地址;
  • port:端口,提供給消費者訪問的端口;
  • weight:權重,當前實例的權限,浮點類型(默認1.0D);
  • healthy:健康狀況,默認true;
  • enabled:實例是否準備好接收請求,默認true;
  • ephemeral:實例是否為瞬時的,默認為true;
  • clusterName:實例所屬的集群名稱;
  • serviceName:實例的服務信息;

Instance類包含了實例的基礎信息之外,還包含了用于存儲元數據的metadata(描述數據的數據),類型為HashMap。

從Demo中放了兩個數據:

netType:顧名思義,網絡類型,這里的值為external,也就是外網的意思;

version:版本,Nacos的版本,這里是2.0這個大版本。

除了Demo中這些“自定義”的信息,在Instance類中還定義了一些默認信息,這些信息通過get方法提供:

  1. public long getInstanceHeartBeatInterval() { 
  2.     return getMetaDataByKeyWithDefault(PreservedMetadataKeys.HEART_BEAT_INTERVAL, 
  3.             Constants.DEFAULT_HEART_BEAT_INTERVAL); 
  4.  
  5. public long getInstanceHeartBeatTimeOut() { 
  6.     return getMetaDataByKeyWithDefault(PreservedMetadataKeys.HEART_BEAT_TIMEOUT, 
  7.             Constants.DEFAULT_HEART_BEAT_TIMEOUT); 
  8.  
  9. public long getIpDeleteTimeout() { 
  10.     return getMetaDataByKeyWithDefault(PreservedMetadataKeys.IP_DELETE_TIMEOUT, 
  11.             Constants.DEFAULT_IP_DELETE_TIMEOUT); 
  12.  
  13. public String getInstanceIdGenerator() { 
  14.     return getMetaDataByKeyWithDefault(PreservedMetadataKeys.INSTANCE_ID_GENERATOR, 
  15.             Constants.DEFAULT_INSTANCE_ID_GENERATOR); 

上面的get方法在需要元數據默認值時會被用到:

  • preserved.heart.beat.interval:心跳間隙的key,默認為5s,也就是默認5秒進行一次心跳;
  • preserved.heart.beat.timeout:心跳超時的key,默認為15s,也就是默認15秒收不到心跳,實例將會標記為不健康;
  • preserved.ip.delete.timeout:實例IP被刪除的key,默認為30s,也就是30秒收不到心跳,實例將會被移除;
  • preserved.instance.id.generator:實例ID生成器key,默認為simple;

這些都是Nacos默認提供的值,也就是當前實例注冊時會告訴Nacos Server說:我的心跳間隙、心跳超時等對應的值是多少,你按照這個值來判斷我這個實例是否健康。當然,如果你想讓心跳“加速”,出現故障快速被移除,那可以跳短心跳間隙和超時時間。但這也意味著給Nacos服務帶來一定的壓力。

有了這些信息,我們基本是已經知道注冊實例時需要傳遞什么參數,需要配置什么參數了。

NamingService接口

NamingService接口是Nacos命名服務對外提供的一個統一接口,看對應的源碼就可以發現,它提供了大量實例相關的接口方法,比如:

  • 服務實例注冊;
  • 服務實例注銷;
  • 獲取服務實例列表;
  • 獲取服務單個實例;
  • 訂閱服務事件;
  • 取消訂閱服務事件;
  • 獲取所有(或指定)服務名稱;
  • 獲取所有訂閱的服務;
  • 獲取Nacos服務的狀態;
  • 主動關閉服務;

其中部分功能提供了大量的重載方法,應用于不同場景和不同類型實例或服務的篩選。這個就不逐一說明,按照需要或注釋進行使用即可。

NamingService的實例化是通過NamingFactory類和上面提到的Nacos服務信息:

  1. public static NamingService createNamingService(Properties properties) throws NacosException { 
  2.     try { 
  3.         Class<?> driverImplClass = Class.forName("com.alibaba.nacos.client.naming.NacosNamingService"); 
  4.         Constructor constructor = driverImplClass.getConstructor(Properties.class); 
  5.         return (NamingService) constructor.newInstance(properties); 
  6.     } catch (Throwable e) { 
  7.         throw new NacosException(NacosException.CLIENT_INVALID_PARAM, e); 
  8.     } 

很明顯,這里采用了反射的機制來實例化NamingService,接口的具體實現類為NacosNamingService類。

NacosNamingService的實現

在示例代碼中使用了NamingService#registerInstance方法來進行服務實例的注冊,該方法接收兩個參數,服務名稱和實例對象。

  1. @Override 
  2. public void registerInstance(String serviceName, Instance instance) throws NacosException { 
  3.     registerInstance(serviceName, Constants.DEFAULT_GROUP, instance); 

這個方法的最大作用是設置了當前實例的分組信息。我們知道,在Nacos中,通過Namespace、group、Service、Cluster等一層層的將實例進行環境的隔離。在這里設置了默認的分組為“DEFAULT_GROUP”。

緊接著調用的registerInstance方法如下:

  1. @Override 
  2. public void registerInstance(String serviceName, String groupName, Instance instance) throws NacosException { 
  3.     NamingUtils.checkInstanceIsLegal(instance); 
  4.     clientProxy.registerService(serviceName, groupName, instance); 

這個方法實現了兩個功能:第一,檢查心跳時間設置的對不對,配置的超時時間總不能比心跳間隔還短吧。第二,通過NamingClientProxy這個代理來執行服務注冊操作。

反觀NacosNamingService構造方法,會發現NamingClientProxy這個代理接口的具體實現是有NamingClientProxyDelegate來完成的。

NamingClientProxyDelegate中實現

NamingClientProxy調用registerService實際上調用的就是NamingClientProxyDelegate的對應方法:

  1. @Override 
  2. public void registerService(String serviceName, String groupName, Instance instance) throws NacosException { 
  3.     getExecuteClientProxy(instance).registerService(serviceName, groupName, instance); 

真正調用注冊服務的并不是代理實現類,而是根據當前實例是否為瞬時對象,來選擇對應的客戶端代理來進行請求的:

  1. private NamingClientProxy getExecuteClientProxy(Instance instance) { 
  2.     return instance.isEphemeral() ? grpcClientProxy : httpClientProxy; 

如果當前實例為瞬時對象,則采用gRPC協議(NamingGrpcClientProxy)進行請求,否則采用http協議(NamingHttpClientProxy)進行請求。默認為瞬時對象,也就是說,2.0版本中默認采用了gRPC協議進行與Nacos服務進行交互。

NamingGrpcClientProxy中實現

關于gRPC協議這部分我們會單獨進行講解,這里暫時不做拓展。主要看其registerService方法實現:

  1. @Override 
  2. public void registerService(String serviceName, String groupName, Instance instance) throws NacosException { 
  3.     NAMING_LOGGER.info("[REGISTER-SERVICE] {} registering service {} with instance {}", namespaceId, serviceName, 
  4.             instance); 
  5.     namingGrpcConnectionEventListener.cacheInstanceForRedo(serviceName, groupName, instance); 
  6.     InstanceRequest request = new InstanceRequest(namespaceId, serviceName, groupName, 
  7.             NamingRemoteConstants.REGISTER_INSTANCE, instance); 
  8.     requestToServer(request, Response.class); 

在NamingGrpcClientProxy中做了兩件事,一件事是通過事件監聽器緩存了當前注冊的實例信息用于恢復。緩存的數據結構為ConcurrentMap

另外一件事就是封裝了參數,基于gRPC協議進行服務的調用和結果的處理。

流程圖

下面來看一張流程圖,來匯總一下上面講到的整個業務邏輯: 

小結

 

關于Nacos源碼分析的開篇就寫這么多,主要分析了服務注冊需要哪些維度的信息、客戶端提供的核心服務處理類(NamingService)以及注冊通信協議的選擇。其中的一些內容還可以細化,比如gRPC協議的實現等,我們后續文章繼續進行呈現。

 

責任編輯:武曉燕 來源: 程序新視界
相關推薦

2021-07-12 08:00:21

Nacos 服務注冊源碼分析

2011-10-31 13:42:46

Android客戶端人人網

2022-04-01 08:31:11

RabbitMQ客戶端Channel

2022-03-29 08:31:18

RabbitMQMQ客戶端

2022-04-07 08:30:57

AMQP協議RabbitMQ客戶端源碼

2015-03-30 14:24:06

網易布局

2022-04-20 08:32:09

RabbitMQ流控制

2022-05-06 07:52:06

Nacos服務注冊

2011-08-17 10:10:59

2021-09-22 15:46:29

虛擬桌面瘦客戶端胖客戶端

2009-11-09 15:49:01

WCF異步調用

2015-01-09 11:49:26

Android源碼下載

2015-01-14 13:59:50

騰訊微博客戶端源碼下載

2009-08-21 15:59:22

服務端與客戶端通信

2009-08-21 16:14:52

服務端與客戶端通信

2011-09-09 09:44:23

WCF

2022-05-08 17:53:38

Nacos服務端客戶端

2021-08-10 07:00:00

Nacos Clien服務分析

2010-05-31 10:11:32

瘦客戶端

2011-06-09 10:51:26

Qt 服務器 客戶端
點贊
收藏

51CTO技術棧公眾號

а√天堂中文在线资源8| 国产欧美久久久精品免费| 国产成人调教视频在线观看| 一本一本大道香蕉久在线精品| 天天爽天天狠久久久| 国产成人三级一区二区在线观看一 | 久久久福利视频| 中文字幕+乱码+中文乱码91| 国内综合精品午夜久久资源| 日韩成人激情在线| 国产无色aaa| 涩涩视频在线播放| 综合久久给合久久狠狠狠97色| 高清国产一区| 黄色一区二区视频| 在线亚洲激情| 久久精品视频一| 香蕉视频黄色在线观看| 国产一区二区三区| 欧洲精品在线观看| 可以看毛片的网址| 久操免费在线| 国产网站一区二区| 国产精品一区视频| 国产草草影院ccyycom| 日韩精品每日更新| 91大神在线播放精品| 在线观看成人毛片| 欧美wwwww| 亚洲欧美日韩天堂一区二区| 精品国产乱码久久久久夜深人妻| 国产福利亚洲| 欧美伊人久久久久久久久影院| 丰满的少妇愉情hd高清果冻传媒| 国产1区在线| 中文字幕国产精品一区二区| 久久精品国产精品国产精品污 | 亚洲天堂网在线视频| 亚洲综合另类| 97成人超碰免| xxxxxx国产| 黄色欧美日韩| 欧美精品激情在线观看| 欧美三级黄色大片| 99视频精品全部免费在线视频| 亚洲视频一区二区| 右手影院亚洲欧美| 天堂av一区二区三区在线播放 | 色素色在线综合| 国产在线精品91| 国产高清自产拍av在线| 亚洲精品乱码久久久久久| 99精品视频网站| 欧美另类极品| 亚洲另类在线制服丝袜| 国产对白在线播放| 怡红院在线播放| 亚洲最大的成人av| 69sex久久精品国产麻豆| 福利网站在线观看| 精品欧美国产一区二区三区| 欧美黑人经典片免费观看| 漫画在线观看av| 欧美日韩另类字幕中文| 精品一卡二卡三卡| 成人做爰视频www网站小优视频| 欧美日韩综合视频网址| 欧美黄色一级片视频| 无人区在线高清完整免费版 一区二| 一本久久a久久免费精品不卡| 欧美视频免费播放| 日本另类视频| 337p亚洲精品色噜噜噜| 少妇伦子伦精品无吗| 国产精品色呦| 亚洲午夜未删减在线观看 | 国产大尺度视频| 少妇精品导航| 色一区av在线| 青青草成人免费| 国产日韩欧美三区| 国产精品免费久久久久影院| 国产精品熟女久久久久久| 国产成人久久精品77777最新版本 国产成人鲁色资源国产91色综 | 亚洲人成电影在线观看天堂色| 亚洲欧美va天堂人熟伦| 亚洲精品一区二区妖精| 久久免费视频这里只有精品| www毛片com| 九九热在线视频观看这里只有精品| 成人免费视频网| 西西人体44www大胆无码| 欧美激情在线观看视频免费| 国产女教师bbwbbwbbw| 五月天av在线| 欧美一区二区免费| xxx在线播放| 一级毛片免费高清中文字幕久久网| 午夜剧场成人观在线视频免费观看| 高清乱码免费看污| 国产福利一区二区三区视频在线| 欧美激情www| www视频在线免费观看| 欧美天堂在线观看| 欧美污在线观看| 国内精品久久久久久久影视简单| 久久天天躁狠狠躁夜夜躁| 中文字幕视频网站| 国产成a人亚洲精品| 日韩免费av一区二区三区| 色av手机在线| 欧美精品aⅴ在线视频| 丰满圆润老女人hd| 精品成人国产| 91在线视频九色| 久热av在线| 亚洲成a人片在线不卡一二三区| 手机视频在线观看| 五月天亚洲一区| 欧美精品videosex性欧美| 夜夜嗨av禁果av粉嫩avhd| 久久综合久久综合久久综合| 国产成人艳妇aa视频在线 | 精品一区二区三区日本| bt在线麻豆视频| 欧美精品第一页| jizz日本在线播放| 日韩在线观看一区二区| 久久国产主播精品| 3344国产永久在线观看视频| 日韩欧美一级在线播放| 亚洲一区电影在线观看| 日本女人一区二区三区| 欧美一区免费视频| 中文字幕这里只有精品| 亚洲国产成人精品一区二区 | 九义人在线观看完整免费版电视剧| 一本一道综合狠狠老| 亚洲av无码一区二区三区观看| 欧美日韩亚洲一区| 91免费版黄色| 在线观看av免费| 91精品国产综合久久精品| fc2ppv在线播放| 捆绑调教美女网站视频一区| 亚洲欧洲国产精品久久| 国产激情欧美| 波霸ol色综合久久| ,一级淫片a看免费| 最新不卡av在线| 三级av免费看| 欧美午夜不卡影院在线观看完整版免费| 91精品久久久久久久久中文字幕| 日本激情在线观看| 欧美日韩国产高清一区二区| 日本黄色录像视频| 精东粉嫩av免费一区二区三区| 一区二区三区四区在线视频| 国产精品成人**免费视频| 久久香蕉国产线看观看av| 999精品国产| 亚洲一区二区免费视频| 精品无码人妻少妇久久久久久| 一本久道久久综合婷婷鲸鱼| 欧美性bbwbbwbbwhd| 亚洲电影有码| 久久艹在线视频| 人妻视频一区二区三区| 欧美午夜电影在线| 色撸撸在线视频| 国产一本一道久久香蕉| 欧美日韩不卡在线视频| 一本久久青青| 91精品久久久久久久久久久| 四虎影院观看视频在线观看| 亚洲高清色综合| 日本三级一区二区三区| **性色生活片久久毛片| 亚洲美女精品视频| 日韩精品91亚洲二区在线观看| 在线国产99| 久久九九热re6这里有精品| 国产激情视频一区| √天堂8在线网| 日韩精品在线观看一区| 在线观看亚洲国产| 亚洲成人黄色影院| av在线播放中文字幕| 粉嫩av亚洲一区二区图片| 欧美精品第三页| 欧美人与禽猛交乱配视频| 欧美凹凸一区二区三区视频| 疯狂欧洲av久久成人av电影| 91福利视频网| 亚洲综合图区| 亚洲性av网站| 日本精品久久久久| 欧美久久一二三四区| 日韩美女一级片| |精品福利一区二区三区| 中文字幕日韩三级片| 久久99国产精品久久| 日本三级免费网站| 欧美成人首页| 亚洲欧洲一二三| 欧美一性一交| 91在线在线观看| 91国内外精品自在线播放| 性欧美办公室18xxxxhd| 大地资源网3页在线观看| 亚洲欧美一区二区三区情侣bbw| 精品人妻一区二区三区浪潮在线 | 伊人国产精品视频| 玖玖在线精品| 奇米精品一区二区三区| 午夜国产精品视频| 亚洲国产一区在线| 欧美禁忌电影| 精品蜜桃传媒| 亚洲精品黑牛一区二区三区| 国产主播欧美精品| 成人看片网页| 国产suv精品一区二区三区88区| 国产蜜臀av在线播放| 久久资源免费视频| 日本成a人片在线观看| 亚洲人午夜精品| 手机在线观看毛片| 亚洲国产精品一区二区三区| 亚洲精品一区二区三区蜜桃| 欧美一级精品大片| 国产美女无遮挡永久免费| 欧美午夜精品久久久久久孕妇| 欧美一级片免费在线观看| 亚洲不卡在线观看| 日本熟妇成熟毛茸茸| 亚洲午夜久久久久久久久电影院 | 少妇视频在线播放| 国产亚洲一本大道中文在线| 鲁大师私人影院在线观看| 99re成人精品视频| 亚洲欧美日本一区| av电影一区二区| 日本japanese极品少妇| 91免费看`日韩一区二区| 国产精品九九视频| 91视频.com| 国产精成人品免费观看| 欧美国产乱子伦| 黄大色黄女片18免费| 国产精品美女一区二区三区| 人与动物性xxxx| 亚洲色大成网站www久久九九| 国产精品免费人成网站酒店| 亚洲美腿欧美偷拍| 国产成人精品av久久| 亚洲成a人片综合在线| 午夜毛片在线观看| 色哟哟精品一区| 中文字幕一区2区3区| 在线不卡一区二区| 亚洲黄色片视频| 日韩国产精品亚洲а∨天堂免| 日本一级在线观看| 一本色道久久综合狠狠躁篇怎么玩| 97电影在线| 久久综合九色九九| 超碰中文在线| 欧美性受xxxx白人性爽| 欧美日韩视频免费观看| 91精品免费看| 噜噜噜狠狠夜夜躁精品仙踪林| 欧美精品123| 91精品国产乱码久久久久久| 精品无码一区二区三区爱欲| 久久亚洲视频| 亚洲三级在线视频| 91网上在线视频| 在线日韩国产网站| 亚洲高清免费视频| 国产精品露脸视频| 亚洲成年人在线播放| h视频在线播放| 欧美激情一区二区三区高清视频| 2022成人影院| 91超碰rencao97精品| 网红女主播少妇精品视频| 警花观音坐莲激情销魂小说| 亚洲精华国产欧美| 亚洲精品综合在线观看| a美女胸又www黄视频久久| 久久精品日韩无码| 精品动漫一区二区| 国产精品毛片一区二区在线看舒淇 | 久久麻豆精品| 欧美一级在线看| 国产精品综合网| 夫妇交换中文字幕| 亚洲成av人片一区二区三区| 国产一区二区麻豆| 亚洲区免费影片| 黄污视频在线观看| 国产欧美中文字幕| 亚洲男人都懂第一日本| 黄色录像特级片| 美女视频黄久久| 欧美精品欧美极品欧美激情| 亚洲人精品一区| 国产天堂第一区| 亚洲人成电影在线播放| 极品av在线| 99九九电视剧免费观看| 久久免费av| 五月婷婷狠狠操| 91色九色蝌蚪| 国产小视频在线看| 7777精品伊人久久久大香线蕉最新版 | 日本h片久久| 欧美一级二级三级九九九| 激情自拍一区| 国产调教打屁股xxxx网站| 国产精品久久久久久久久免费樱桃| 免费黄色网址在线| 亚洲精品美女久久久| h片在线观看视频免费免费| 91在线播放视频| 欧美一区精品| 亚洲天堂网站在线| 成人欧美一区二区三区视频网页| 波多野结衣日韩| 国产亚洲a∨片在线观看| 亚洲小少妇裸体bbw| 国产成人精品自拍| 欧美另类专区| 国产日韩视频一区| 亚洲一区二区三区美女| 亚洲精品一区二区三区不卡| 色综合91久久精品中文字幕| 亚洲超碰在线观看| 欧美狂野激情性xxxx在线观| 国产99久久久久久免费看农村| 国产少妇在线观看| 日韩一级完整毛片| 最新国产露脸在线观看| 999视频在线免费观看| 欧美黄色一级视频| 国产ts在线观看| www.国产精品.com| 久久成人综合视频| 97久久中文字幕 | 午夜精品剧场| 一二三区视频在线观看| 亚洲国产aⅴ天堂久久| 日本精品久久久久| 欧美一性一乱一交一视频| 欧美禁忌电影| 国产一级片自拍| 亚洲欧美国产高清| 亚洲黄色在线观看视频| 91精品国产色综合久久不卡98| 色婷婷久久久| 鲁一鲁一鲁一鲁一av| 亚洲日本在线观看| 午夜久久久久久噜噜噜噜| 午夜精品理论片| 国产aⅴ精品一区二区三区久久| 性chinese极品按摩| 亚洲女与黑人做爰| 熟妇高潮一区二区三区| 国产精品成人免费视频| 久久久久久久久99精品大| 少妇献身老头系列| 第一福利永久视频精品| av资源网在线观看| 91精品国产高清久久久久久91裸体| 精品福利电影| 我想看黄色大片| 欧美成人一区二区三区片免费| av日韩中文| 日韩精品最新在线观看| 夫妻av一区二区| 中文字幕av影院| 久久伊人精品一区二区三区| 精品素人av| 在线观看免费不卡av| 亚洲国产视频一区二区| 黄色免费在线播放| 亚洲va欧美va国产综合剧情| 亚洲专区一区| 51精品免费网站| 精品一区二区三区四区在线| 91精品麻豆| 18岁视频在线观看| 亚洲精品国产高清久久伦理二区| 你懂的好爽在线观看| 97人人香蕉| 麻豆精品一区二区综合av| 97超碰人人干| 欧美成人精品在线观看| 欧美理论电影大全|