在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

NacosServiceRegistry的實現

Android編程精選 ? 來源:CSDN ? 作者:吳聲子夜歌 ? 2022-09-13 10:51 ? 次閱讀

Nacos架構

342d8b58-328f-11ed-ba43-dac502259ad0.png

Provider APP:服務提供者

Consumer APP:服務消費者

Name Server:通過VIP(Virtual IP)或DNS的方式實現Nacos高可用集群的服務路由

Nacos Server:Nacos服務提供者,里面包含的Open API是功能訪問入口,Conig Service、Naming Service 是Nacos提供的配置服務、命名服務模塊。Consitency Protocol是一致性協議,用來實現Nacos集群節點的數據同步,這里使用的是Raft算法(Etcd、Redis哨兵選舉)

Nacos Console:控制臺

346023f6-328f-11ed-ba43-dac502259ad0.jpg

注冊中心的原理

服務實例在啟動時注冊到服務注冊表,并在關閉時注銷

服務消費者查詢服務注冊表,獲得可用實例

服務注冊中心需要調用服務實例的健康檢查API來驗證它是否能夠處理請求

346e7c76-328f-11ed-ba43-dac502259ad0.png

SpringCloud完成注冊的時機

在Spring-Cloud-Common包中有一個類org.springframework.cloud. client.serviceregistry .ServiceRegistry,它是Spring Cloud提供的服務注冊的標準。集成到Spring Cloud中實現服務注冊的組件,都會實現該接口

349b4dd2-328f-11ed-ba43-dac502259ad0.png

該接口有一個實現類是NacoServiceRegistry。

SpringCloud集成Nacos的實現過程:

在spring-clou-commons包的META-INF/spring.factories中包含自動裝配的配置信息如下:

34c4dbfc-328f-11ed-ba43-dac502259ad0.png

其中AutoServiceRegistrationAutoConfiguration就是服務注冊相關的配置類:

34f369d6-328f-11ed-ba43-dac502259ad0.png

在AutoServiceRegistrationAutoConfiguration配置類中,可以看到注入了一個AutoServiceRegistration實例,該類的關系圖如下所示。

35280326-328f-11ed-ba43-dac502259ad0.png

可以看出,AbstractAutoServiceRegistration抽象類實現了該接口,并且最重要的是NacosAutoServiceRegistration繼承了AbstractAutoServiceRegistration。

看到EventListener我們就應該知道,Nacos是通過Spring的事件機制繼承到SpringCloud中去的。

AbstractAutoServiceRegistration實現了onApplicationEvent抽象方法,并且監聽WebServerInitializedEvent事件(當Webserver初始化完成之后) , 調用this.bind ( event )方法。

3555ed54-328f-11ed-ba43-dac502259ad0.png

最終會調用NacosServiceREgistry.register()方法進行服務注冊。

35731e88-328f-11ed-ba43-dac502259ad0.png359a4cc4-328f-11ed-ba43-dac502259ad0.png

NacosServiceRegistry的實現

在NacosServiceRegistry.registry方法中,調用了Nacos Client SDK中的namingService.registerInstance完成服務的注冊。

35b8d572-328f-11ed-ba43-dac502259ad0.png

跟蹤NacosNamingService的registerInstance()方法:

35e49b8a-328f-11ed-ba43-dac502259ad0.png

通過beatReactor.addBeatInfo()創建心跳信息實現健康檢測, Nacos Server必須要確保注冊的服務實例是健康的,而心跳檢測就是服務健康檢測的手段。

serverProxy.registerService()實現服務注冊

心跳機制:

36133a8a-328f-11ed-ba43-dac502259ad0.png

從上述代碼看,所謂心跳機制就是客戶端通過schedule定時向服務端發送一個數據包 ,然后啟動-個線程不斷檢測服務端的回應,如果在設定時間內沒有收到服務端的回應,則認為服務器出現了故障。Nacos服務端會根據客戶端的心跳包不斷更新服務的狀態。

注冊原理:

Nacos提供了SDK和Open API兩種形式來實現服務注冊。

Open API:

3640b91a-328f-11ed-ba43-dac502259ad0.png

SDK:

3664c378-328f-11ed-ba43-dac502259ad0.png

這兩種形式本質都一樣,底層都是基于HTTP協議完成請求的。所以注冊服務就是發送一個HTTP請求:367d1db0-328f-11ed-ba43-dac502259ad0.png

對于nacos服務端,對外提供的服務接口請求地址為nacos/v1/ns/instance,實現代碼咋nacos-naming模塊下的InstanceController類中:

37690f0e-328f-11ed-ba43-dac502259ad0.png

從請求參數匯總獲得serviceName(服務名)和namespaceId(命名空間Id)

調用registerInstance注冊實例。

379e29dc-328f-11ed-ba43-dac502259ad0.png

創建一個控服務(在Nacos控制臺“服務列表”中展示的服務信息),實際上是初始化一個serviceMap,它是一個ConcurrentHashMap集合

getService,從serviceMap中根據namespaceId和serviceName得到一個服務對象

調用addInstance添加服務實例

37cfe13e-328f-11ed-ba43-dac502259ad0.png381640fc-328f-11ed-ba43-dac502259ad0.png

根據namespaceId、serviceName從緩存中獲取Service實例

如果Service實例為空,則創建并保存到緩存中

382fab6e-328f-11ed-ba43-dac502259ad0.png

通過putService()方法將服務緩存到內存

service.init()建立心跳機制

consistencyService.listen實現數據一致性監聽

service.init ( )方法的如下圖所示,它主要通過定時任務不斷檢測當前服務下所有實例最后發送心跳包的時間。如果超時,則設置healthy為false表示服務不健康,并且發送服務變更事件。

在這里請大家思考一一個問題,服務實例的最后心跳包更新時間是誰來觸發的?實際上前面有講到, Nacos客戶端注冊服務的同時也建立了心跳機制。

38614c32-328f-11ed-ba43-dac502259ad0.png

putService方法,它的功能是將Service保存到serviceMap中:

3884b474-328f-11ed-ba43-dac502259ad0.png

繼續調用addInstance方法把當前注冊的服務實例保存到Service中:

38ad942a-328f-11ed-ba43-dac502259ad0.png

總結:

Nacos客戶端通過Open API的形式發送服務注冊請求

Nacos服務端收到請求后,做以下三件事:

構建一個Service對象保存到ConcurrentHashMap集合中

使用定時任務對當前服務下的所有實例建立心跳檢測機制

基于數據一致性協議服務數據進行同步

服務提供者地址查詢

Open API:

38c5a006-328f-11ed-ba43-dac502259ad0.png

SDK:

38d74252-328f-11ed-ba43-dac502259ad0.png

InstanceController中的list方法:

38f32a58-328f-11ed-ba43-dac502259ad0.png

解析請求參數。

通過doSrvIPXT返回服務列表數據

39398002-328f-11ed-ba43-dac502259ad0.png399643b4-328f-11ed-ba43-dac502259ad0.png

根據namespaceId、serviceName獲得Service實例

從Service實例中基于srvIPs得到所有服務提供者實例

遍歷組裝JSON字符串并返回

Nacos服務地址動態感知原理

可以通過subscribe方法來實現監聽,其中serviceName表示服務名、EventListener表示監聽到的事件:

39ceeaca-328f-11ed-ba43-dac502259ad0.png

具體調用方式如下:

39e38f48-328f-11ed-ba43-dac502259ad0.png

或者調用selectInstance方法,如果將subscribe屬性設置為true,會自動注冊監聽:

3a126dd6-328f-11ed-ba43-dac502259ad0.png3a354cde-328f-11ed-ba43-dac502259ad0.png

Nacos客戶端中有一個HostReactor類,它的功能是實現服務的動態更新,基本原理是:

客戶端發起時間訂閱后,在HostReactor中有一個UpdateTask線程,每10s發送一次Pull請求,獲得服務端最新的地址列表

另外,搜索公眾號Java架構師技術后臺回復“Spring”,獲取一份驚喜禮包。

對于服務端,它和服務提供者的實例之間維持了心跳檢測,一旦服務提供者出現異常,則會發送一個Push消息給Nacos客戶端,也就是服務端消費者

服務消費者收到請求之后,使用HostReactor中提供的processServiceJSON解析消息,并更新本地服務地址列表。



審核編輯:劉清

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • API
    API
    +關注

    關注

    2

    文章

    1510

    瀏覽量

    62341
  • DNS
    DNS
    +關注

    關注

    0

    文章

    219

    瀏覽量

    19919
  • SDK
    SDK
    +關注

    關注

    3

    文章

    1045

    瀏覽量

    46199
  • HTTP協議
    +關注

    關注

    0

    文章

    66

    瀏覽量

    9773

原文標題:Nacos 為什么這么強!Nacos實現原理詳解。。

文章出處:【微信號:AndroidPush,微信公眾號:Android編程精選】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    WEBENCH電源設計與實現

    電子發燒友網站提供《WEBENCH電源設計與實現.pdf》資料免費下載
    發表于 01-21 14:52 ?0次下載
    WEBENCH電源設計與<b class='flag-5'>實現</b>

    基于FPGA實現圖像直方圖設計

    直方圖統計的原理 直方圖統計從數學上來說,是對圖像中的像素點進行統計。圖像直方圖統計常用于統計灰度圖像,表示圖像中各個灰度級出現的次數或者概率。統計直方圖的實現采用C/C++或者其他高級語言實現十分
    的頭像 發表于 12-24 10:24 ?200次閱讀
    基于FPGA<b class='flag-5'>實現</b>圖像直方圖設計

    智能制造如何實現

    智能制造的實現是一個系統性工程,涉及技術、流程、組織結構等多個方面的變革。以下是實現智能制造的關鍵步驟和方法: 1. 技術升級和應用:智能制造的實現需要依托先進的信息技術,包括工業互聯網、5G
    的頭像 發表于 11-20 09:43 ?698次閱讀

    PowerPAD?輕松實現

    電子發燒友網站提供《PowerPAD?輕松實現.pdf》資料免費下載
    發表于 10-29 10:08 ?0次下載
    PowerPAD?輕松<b class='flag-5'>實現</b>

    通過電平轉換實現窄帶IoT實現

    電子發燒友網站提供《通過電平轉換實現窄帶IoT實現.pdf》資料免費下載
    發表于 09-21 11:08 ?0次下載
    通過電平轉換<b class='flag-5'>實現</b>窄帶IoT<b class='flag-5'>實現</b>

    使用DSPLIB FFT實現實現實際輸入,無需數據縮放

    電子發燒友網站提供《使用DSPLIB FFT實現實現實際輸入,無需數據縮放.pdf》資料免費下載
    發表于 09-19 11:27 ?0次下載
    使用DSPLIB FFT<b class='flag-5'>實現實現</b>實際輸入,無需數據縮放

    如何實現多枚TAS5630并聯實現更多功率輸出?

    我想請教下,如何實現多枚TAS5630并聯實現更多功率輸出,謝謝
    發表于 09-13 06:47

    labview實現tcp通訊

    labview實現tcp通訊
    發表于 08-19 14:26 ?15次下載

    如何實現pwm的控制功能

    數字信號控制技術,通過控制脈沖的占空比來實現對模擬信號的控制。占空比是指在一個周期內,脈沖的高電平時間與整個周期時間的比值。 特點 PWM具有以下特點: (1)簡單易實現:PWM只需要數字信號,不需要模擬信號,因此實現起來相對簡
    的頭像 發表于 08-08 15:08 ?897次閱讀

    PWM控制電機轉速的原理與實現

    PWM(脈寬調制)是一種廣泛應用于電機控制領域的調制技術。它通過調節脈沖信號的占空比,實現對電機轉速的精確控制。PWM控制電機轉速的方法因其高效、穩定、易于實現等優點,在現代工業、家電、汽車等領域得到了廣泛應用。本文將詳細介紹PWM控制電機轉速的原理、
    的頭像 發表于 06-03 17:23 ?6623次閱讀

    STM8如何實現批量燒錄?

    如題,是否可以實現? 如何實現? STM8 通過SWIM(ICP)是否能夠實現多機通訊?
    發表于 04-30 06:49

    PLC如何實現監視功能?

    PLC(Programmable Logic Controller)實現監視功能主要依賴于其編程軟件中的專門監視窗口。
    的頭像 發表于 04-01 10:08 ?2398次閱讀

    stm32h750既要實現主機,也要實現從機功能,要怎么實現呢?

    h750的板子實現OTG功能,作為主機識別接入的u盤;作為從機接入電腦時,模擬成一個u盤。 在cubemx中USB_OTG_FS的mode中選擇OTG/Dual_Role_Device,在
    發表于 03-19 06:46

    【鴻蒙】NAPI 框架生成工具實現流程

    開發者無需關注 Nodejs 語法、C++ 與 JS 之間的數據類型轉換等上層應用轉換邏輯,只關注底層業務邏輯即可。 那他的實現過程,以及在實際開發中該如何使用呢?為此分析了下代碼,分解其過程如下。 1.
    的頭像 發表于 02-28 17:00 ?726次閱讀
    【鴻蒙】NAPI 框架生成工具<b class='flag-5'>實現</b>流程

    電阻是如何實現上下拉功能的呢?

    電阻是如何實現上下拉功能的呢? 上下拉功能是指在電路中通過連接電阻來實現對信號的上拉和下拉控制。在數字電路中,上拉和下拉功能通常用于控制輸入端的電平狀態,確保輸入端在沒有外部信號輸入時能夠保持穩定
    的頭像 發表于 02-04 09:32 ?1023次閱讀
    主站蜘蛛池模板: 色婷婷色综合激情国产日韩 | 免费一级特黄欧美大片勹久久网 | 高清一级做a爱视频免费 | 美女免费视频是黄的 | 羞羞漫画喷水漫画yy漫画 | 色播影院性播免费看 | 夜夜春夜夜爽 | 亚洲性视频网站 | 欧美日韩国产一区二区三区不卡 | 亚洲男人天堂2020 | 天天躁天天狠天天透 | 日本黄色大全 | 国产精品高清免费网站 | 操一操干一干 | 美女被免费视频的网站 | 2021国产精品久久 | 三级精品视频在线播放 | 日本人zzzwww | 激情都市亚洲 | 国产三级观看 | 一本大道一卡二卡 | 三级网址在线 | 久久黄色视屏 | 日本视频www | 五月天婷五月天综合网在线 | 国产午夜精品一区二区三区 | 狠狠色丁香六月色 | 美女扒开尿囗给男生桶爽 | 96福利视频 | 色屋网| 天天干天天操天天添 | 亚洲高清免费观看 | 羞羞答答91麻豆网站入口 | 国产视频资源 | 香蕉久久夜色精品国产2020 | 在线视频一区二区三区 | 日韩毛片在线影视 | 色视频网站免费 | 在线看片地址 | 欧洲性freefree大白屁股 | 最近2018中文字幕免费看手机 |