色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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

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

3天內不再提示

Nacos、OpenFeign、Ribbon組件協調工作的原理

jf_ro2CN3Fa ? 來源:三友的java日記 ? 2023-05-22 10:46 ? 次閱讀

Nacos

如何進行服務自動注冊?

Ribbon

OpenFeign

總結

前幾天有個大兄弟問了我一個問題,注冊中心要集成SpringCloud,想實現SpringCloud的負載均衡,需要實現哪些接口和規范。

既然這個兄弟問到我了,而我又剛好知道,這不得好好寫一篇文章來回答這個問題,雖然在后面的聊天中我已經回答過了。

接下來本文就來探究一下Nacos、OpenFeign、Ribbon、loadbalancer等組件協調工作的原理,知道這些原理之后,就知道應該需要是實現哪些接口了。

Nacos

先從Nacos講起。

Nacos是什么,官網中有這么一段話

5c6baf8c-f7ce-11ed-90ce-dac502259ad0.png

這一段話說的直白點就是Nacos是一個注冊中心和配置中心!

在Nacos中有客戶端和服務端的這個概念

5c73dab8-f7ce-11ed-90ce-dac502259ad0.png

服務端需要單獨部署,用來保存服務實例數據的

客戶端就是用來跟服務端通信SDK,支持不同語言

當需要向Nacos服務端注冊或者獲取服務實例數據的時候,只需要通過Nacos提供的客戶端SDK就可以了,就像下面這樣:

引入依賴


com.alibaba.nacos
nacos-client
1.4.4

示例代碼

Propertiesproperties=newProperties();
properties.setProperty("serverAddr","localhost");
properties.setProperty("namespace","8848");

NamingServicenaming=NamingFactory.createNamingService(properties);

//服務注冊,注冊一個order服務,order服務的ip是192.168.2.100,端口8080
naming.registerInstance("order","192.168.2.100",8080);

//服務發現,獲取所有的order服務實例
ListinstanceList=naming.selectInstances("order",true);

當服務注冊到Nacos服務端的時候,在服務端內部會有一個集合去存儲服務的信息

5c866fb6-f7ce-11ed-90ce-dac502259ad0.png

這個集合在注冊中心界中有個響亮的名字,服務注冊表

如何進行服務自動注冊?

用過SpringCloud的小伙伴肯定知道,在項目啟動的時候服務能夠自動注冊到服務注冊中心,并不需要手動寫上面那段代碼,那么服務自動注冊是如何實現的呢?

服務自動注冊三板斧

SpringCloud本身提供了一套服務自動注冊的機制,或者說是約束,其實就是三個接口,只要注冊中心實現這些接口,就能夠在服務啟動時自動注冊到注冊中心,而這三個接口我稱為服務自動注冊三板斧。

服務實例數據封裝--Registration

Registration是SpringCloud提供的一個接口,繼承了ServiceInstance接口

5c90b9b2-f7ce-11ed-90ce-dac502259ad0.pngRegistration 5c9ae644-f7ce-11ed-90ce-dac502259ad0.pngServiceInstance

從ServiceInstance的接口定義可以看出,這是一個服務實例數據的封裝,比如這個服務的ip是多少,端口號是多少。

所以Registration就是當前服務實例數據封裝,封裝了當前服務的所在的機器ip和端口號等信息。

Nacos既然要整合SpringCloud,自然而然也實現了這個接口

5ca5fb7e-f7ce-11ed-90ce-dac502259ad0.pngNacosRegistration

這樣當前服務需要被注冊到注冊中心的信息就封裝好了。

服務注冊--ServiceRegistry

ServiceRegistry也是個接口,泛型就是上面提到的服務實例數據封裝的接口

5cb94a76-f7ce-11ed-90ce-dac502259ad0.pngServiceRegistry

這個接口的作用就是把上面封裝的當前服務的數據Registration注冊通過register方法注冊到注冊中心中。

Nacos也實現了這個接口。

5cc43562-f7ce-11ed-90ce-dac502259ad0.pngNacosServiceRegistry

并且核心的注冊方法的實現代碼跟前面的demo幾乎一樣

5cce874c-f7ce-11ed-90ce-dac502259ad0.png

服務自動注冊--AutoServiceRegistration

5ce63bbc-f7ce-11ed-90ce-dac502259ad0.pngAutoServiceRegistration

AutoServiceRegistration是一個標記接口,所以本身沒有實際的意義,僅僅代表了自動注冊的意思。

AutoServiceRegistration有個抽象實現AbstractAutoServiceRegistration

5cf02f6e-f7ce-11ed-90ce-dac502259ad0.pngAbstractAutoServiceRegistration是個抽象類

AbstractAutoServiceRegistration實現了ApplicationListener,監聽了WebServerInitializedEvent事件。

WebServerInitializedEvent這個事件是SpringBoot在項目啟動時,當諸如tomcat這類Web服務啟動之后就會發布,注意,只有在Web環境才會發布這個事件。

5cfea53a-f7ce-11ed-90ce-dac502259ad0.png

ServletWebServerInitializedEvent繼承自WebServerInitializedEvent。

所以一旦當SpringBoot項目啟動,tomcat等web服務器啟動成功之后,就會觸發AbstractAutoServiceRegistration監聽器的執行。

最終就會調用ServiceRegistry注冊Registration,實現服務自動注冊

5d09a0fc-f7ce-11ed-90ce-dac502259ad0.png

Nacos自然而然也繼承了AbstractAutoServiceRegistration

5d13ef80-f7ce-11ed-90ce-dac502259ad0.pngNacosAutoServiceRegistration

對于Nacos而言,就將當前的服務注冊的ip和端口等信息,就注冊到了Nacos服務注冊中心。

所以整個注冊流程就可以用這么一張圖概括

5d22304a-f7ce-11ed-90ce-dac502259ad0.png

當然,不僅僅是Nacos是這么實現的,常見的比如Eureka、Zookeeper等注冊中心在整合SpringCloud都是實現上面的三板斧。

5d2e6234-f7ce-11ed-90ce-dac502259ad0.png

基于 Spring Boot + MyBatis Plus + Vue & Element 實現的后臺管理系統 + 用戶小程序,支持 RBAC 動態權限、多租戶、數據權限、工作流、三方登錄、支付、短信、商城等功能

項目地址:https://github.com/YunaiV/ruoyi-vue-pro

視頻教程:https://doc.iocoder.cn/video/

Ribbon

講完了SpringCloud環境底下是如何自動注冊服務到注冊中心的,下面來講一講Ribbon。

我們都知道,Ribbon是負載均衡組件,他的作用就是從眾多的服務實例中根據一定的算法選擇一個服務實例。

但是有個疑問,服務實例的數據都在注冊中心,Ribbon是怎么知道的呢???

答案其實很簡單,那就是需要注冊中心去主動適配 Ribbon,只要注冊中心去適配了Ribbon,那么Ribbon自然而然就知道服務實例的數據了。

Ribbon提供了一個獲取服務實例的接口,叫ServerList

5d398a6a-f7ce-11ed-90ce-dac502259ad0.pngServerList

接口中提供了兩個方法,這兩個方法在眾多的實現中實際是一樣的,并沒有區別。

當Ribbon通過ServerList獲取到服務實例數據之后,會基于這些數據來做負載均衡的。

Nacos自然而然也實現了ServerList接口,為Ribbon提供Nacos注冊中心中的服務數據。

5d439c62-f7ce-11ed-90ce-dac502259ad0.pngNacosServerList

這樣,Ribbon就能獲取到了Nacos服務注冊中心的數據。

同樣地,除了Nacos之外,Eureka、Zookeeper等注冊中心也都實現了這個接口。

5d4cc2ec-f7ce-11ed-90ce-dac502259ad0.png

到這,其實就明白了Ribbon是如何知道注冊中心的數據了,需要注冊中心來適配。

在這里插個個人的看法,其實我覺得Ribbon在適配SpringCloud時對獲取服務實例這塊支持封裝的不太好。

5d59e2ba-f7ce-11ed-90ce-dac502259ad0.jpg

因為SpringCloud本身就是一套約束、規范,只要遵守這套規范,那么就可以實現各個組件的替換,這就是為什么換個注冊中心只需要換個依賴,改個配置文件就行。

而Ribbon本身是一個具體的負載均衡組件,注冊中心要想整合SpringCloud,還得需要單獨去適配Ribbon,有點違背了SpringCloud約束的意義。

就類似mybatis一樣,mybatis依靠jdbc,但是mybatis根本不關心哪個數據庫實現的jdbc。

真正好的做法是Ribbon去適配SpringCloud時,用SpringCloud提供的api去獲取服務實例,這樣不同的注冊中心只需要適配這個api,無需單獨適配Ribbon了。

而SpringCloud實際上是提供了這么一個獲取服務實例的api,DiscoveryClient

5d62b444-f7ce-11ed-90ce-dac502259ad0.pngDiscoveryClient

通過DiscoveryClient就能夠獲取到服務實例,當然也是需要不同注冊中心的適配。

5d6c5b48-f7ce-11ed-90ce-dac502259ad0.png

隨著Ribbon等組件停止維護之后,SpringCloud官方自己也搞了一個負載均衡組件loadbalancer,用來平替Ribbon。


org.springframework.cloud
spring-cloud-starter-loadbalancer
2.2.5.RELEASE

這個組件底層在獲取服務實例的時候,就是使用的DiscoveryClient。

5d7b6962-f7ce-11ed-90ce-dac502259ad0.png

所以對于loadbalancer這個負載均衡組價來說,注冊中心只需要實現DiscoveryClient之后就自然而然適配了loadbalancer。

基于 Spring Cloud Alibaba + Gateway + Nacos + RocketMQ + Vue & Element 實現的后臺管理系統 + 用戶小程序,支持 RBAC 動態權限、多租戶、數據權限、工作流、三方登錄、支付、短信、商城等功能

項目地址:https://github.com/YunaiV/yudao-cloud

視頻教程:https://doc.iocoder.cn/video/

OpenFeign

OpenFeign是一個rpc框架,當我們需要調用遠程服務的時候,只需要聲明個接口就可以遠程調用了,就像下面這樣

5d859a36-f7ce-11ed-90ce-dac502259ad0.png

聽上去很神奇,其實本質上就是后面會為接口創建一個動態代理對象,解析類上,方法上的注解。

當調用方法的時候,會根據方法上面的參數拼接一個http請求地址,這個地址的格式是這樣的http://服務名/接口路徑。

比如,上面的例子,當調用saveOrder方法的時候,按照這種規律拼出的地址就是這樣的 http://order/order,第一個order是服務名,第二個order是PostMapping注解上面的。

但是由于只知道需要調用服務的服務名,不知道服務的ip和端口,還是無法調用遠程服務,這咋辦呢?

這時就輪到Ribbon登場了,因為Ribbon這個大兄弟知道服務實例的數據。

于是乎,OpenFeign就對Ribbon說,兄弟,你不是可以從注冊中心獲取到order服務所有服務實例數據么,幫我從這些服務實例數據中找一個給我。

5d8df4d8-f7ce-11ed-90ce-dac502259ad0.png

于是Ribbon就會從注冊中心獲取到的服務實例中根據負載均衡策略選擇一個服務實例返回給OpenFeign。

OpenFeign拿到了服務實例,此時就獲取到了服務所在的ip和端口,接下來就會重新構建請求路徑,將路徑中的服務名替換成ip和端口,代碼如下

5d94759c-f7ce-11ed-90ce-dac502259ad0.pngreconstructURIWithServer

Server就是服務實例信息的封裝

orignal就是原始的url,就是上面提到的,http://order/order

假設獲取到的orde服務所在的ip和端口分別是192.168.2.100和8080,最終重構后的路徑就是http://192.168.2.100:8080/order,之后OpenFeign就可以發送http請求了。

至于前面提到的loadbalancer,其實也是一樣的,他也會根據負載均衡算法,從DiscoveryClient獲取到的服務實例中選擇一個服務實例給OpenFeign,后面也會根據服務實例重構url,再發送http請求。

5da1c3dc-f7ce-11ed-90ce-dac502259ad0.pngloadbalancer組件重構url代碼

總結

到這,就把Nacos、OpenFeign、Ribbon、loadbalancer等組件協調工作的原理講完了,其實就是各個組件會預留一些擴展接口,這也是很多開源框架都會干的事,當第三方框架去適配的,只要實現這些接口就可以了。

最后畫一張圖來總結一下上述組價的工作的原理。

5dacdd58-f7ce-11ed-90ce-dac502259ad0.png

審核編輯:彭靜

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

    關注

    33

    文章

    8577

    瀏覽量

    151023
  • 服務端
    +關注

    關注

    0

    文章

    66

    瀏覽量

    7006
  • nacos
    +關注

    關注

    0

    文章

    10

    瀏覽量

    197

原文標題:終于搞懂了 Nacos、OpenFeign、Ribbon 等組件協調工作的原理,太強了!

文章出處:【微信號:芋道源碼,微信公眾號:芋道源碼】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    Nacos是什么?Nacos配置管理技巧你知道嗎

    Nacos 是阿里巴巴今年7月份開源的項目,如其名, Naming Configuration Service ,專注于服務發現和配置管理領域。本系列文章,將從 5W1H(What、Where
    的頭像 發表于 10-29 08:53 ?1.5w次閱讀

    Nacos的概念和功能

    1、Nacos簡介 Nacos的概念和功能 Nacos是一個面向微服務架構的動態服務發現、配置管理和服務治理平臺,它能夠幫助開發人員和運維人員實現服務注冊、配置管理、DNS和負載均衡等功能。 下面
    的頭像 發表于 09-25 11:02 ?2323次閱讀

    支持Dubbo生態發展,阿里巴巴啟動新的開源項目 Nacos

    摘要: 上周六的Aliware技術行上海站Dubbo開發者沙龍上,阿里巴巴高級技術專家郭平(坤宇)宣布了阿里巴巴的一個新開源計劃,阿里巴巴計劃在7月份開啟一個名叫Nacos的新開源項目, 在活動演講
    發表于 07-05 17:35

    如何為常規Python App包含Qtitan組件

    Developer Machines公司主要為開源UI開發框架QT提供商業組件,其中擁有Chart、DataGrid、Ribbon等控件。本文主要介紹如何為常規Python App包含Qtitan
    發表于 12-17 07:45

    構建ARM64版本nacos docker鏡像

    在適配過程中有大量合作伙伴用到nacos且采用容器化部署,dockerhub未提供官方鏡像,因此需要在鯤鵬服務器自定義構建。構建前提:Docker已部署構建步驟:1、下載包含構建所需的腳本下載完成
    發表于 06-16 14:29

    微服務配置中心實戰:Spring + MyBatis + Druid + Nacos

    在 結合場景談服務發現和配置 中我們講述了 Nacos 配置中心的三個典型的應用場景,包括如何在 Spring Boot 中使用 Nacos 配置中心將數據庫連接信息管控起來,而在“原生
    發表于 12-29 17:09 ?1104次閱讀
    微服務配置中心實戰:Spring + MyBatis + Druid + <b class='flag-5'>Nacos</b>

    Nacos 1.1.4 發布,業界率先支持 Istio MCP 協議

    Nacos是阿里巴巴開源的服務發現與配置管理項目,本次發布的1.1.4版本,主要帶來的是與Istio的對接功能,使用的是Istio最新的MCP協議。本文將介紹包括這個功能在內的新版本發布的功能。升級
    發表于 11-14 23:06 ?1552次閱讀

    ApiBoot Logging使用Spring Cloud Openfeign透傳鏈路信息

    ApiBoot Logging可以無縫整合SpringCloud來采集請求日志,目前支持RestTemplate、Openfeign兩種方式,我們本章來講解下在使用Openfeign...
    的頭像 發表于 12-10 22:05 ?535次閱讀

    Nacos服務地址動態感知原理

    Nacos Server:Nacos服務提供者,里面包含的Open API是功能訪問入口,Conig Service、Naming Service 是Nacos提供的配置服務、命名服務模塊。
    的頭像 發表于 09-26 10:40 ?1763次閱讀

    Nacos為什么這么強?Nacos注冊中心的底層原理,從服務注冊到服務發現

    來源:碼猿技術專欄 1. Nacos介紹 2. Nacos注冊中心實現原理分析 2.1 Nacos架構圖 2.2 注冊中心的原理 3. Nacos源碼分析 3.1
    的頭像 發表于 10-08 16:46 ?1.2w次閱讀

    華為云CSE 關鍵特性,支持托管Nacos注冊配置中心

    華為云CSE關鍵特性,支持托管Nacos注冊配置中心 什么是Nacos Nacos是?Dynamic Naming and Configuration Service的首字母簡稱,相較之下,它更易
    的頭像 發表于 12-29 16:23 ?1020次閱讀
    華為云CSE 關鍵特性,支持托管<b class='flag-5'>Nacos</b>注冊配置中心

    華為云微服務引擎0停機遷移Nacos?它是這樣做的

    使用CSE,但是目前想使用Nacos過渡情況。 ? 傾向使用Nacos作為配置中心使用,其它使用華為云的其它組件,如CCE、中間件等。
    的頭像 發表于 12-29 20:01 ?766次閱讀

    Nacos測試環境中cpu飆高的原因和解決方案

    出問題的項目是 需要連接各個不同nacos 和不同的 namespace 進行對應操作的 一個項目,對nacos的操作都是httpClient 調用的api接口,httpClient方法 沒有問題,不用質疑這個
    發表于 05-12 11:20 ?3303次閱讀
    <b class='flag-5'>Nacos</b>測試環境中cpu飆高的原因和解決方案

    Nacos實現原理:SpringCloud集成Nacos的實現過程

    Nacos服務提供者,里面包含的Open API是功能訪問入口,Conig Service、Naming Service 是Nacos提供的配置服務、命名服務模塊。Consitency
    發表于 10-09 16:08 ?1070次閱讀
    <b class='flag-5'>Nacos</b>實現原理:SpringCloud集成<b class='flag-5'>Nacos</b>的實現過程

    springcloud alibaba 五大組件

    與發現組件Nacos): Nacos是一個用于實現服務注冊和發現的組件。它提供了一個簡單易用的界面來注冊、發現和管理服務實例,同時還支持動態配置、服務路由和流量管理等功能。
    的頭像 發表于 12-03 16:30 ?2w次閱讀
    主站蜘蛛池模板: 双手绑在床头调教乳尖| 久久精品一区二区免费看| 国产中文字幕一区| 日韩爽爽影院在线播放| 99精品成人无码A片观看金桔| 久久精品国产欧美日韩99热| 性满足久久久久久久久| 国产伦子沙发午休系列资源曝光| 色爰情人网站| 闺蜜撬开我的腿用黄瓜折磨我| 日本一卡二卡三卡四卡无卡免费播放| 2019香蕉在线观看直播视频| 九九热最新视频| 印度最猛性ⅹxxxxx| 久久亚洲精品AV成人无| 中文字幕按摩| 暖暖日本免费播放| wwwxx日本| 世界第一黄暴漫画家| 国产精品伊人| 亚洲三级在线看| 久久综合狠狠综合久久综合88| 18禁无遮挡羞羞污污污污免费| 美女的jj| 草莓国产视频免费观看| 玩两个少妇女邻居| 精品96在线观看影院| 又黄又爽又无遮挡在线观看免费| 老师的蕾丝小内内湿透了| a视频免费在线| 天堂在线亚洲精品专区| 国产亚洲精品在浅麻豆| 永久久久免费人妻精品| 免费韩国伦理2017最新| 擦擦擦在线视频观看| 无码日韩人妻精品久久蜜桃免费| 好紧小嫩嫩水的10p| 91极品蜜桃臀在线播放| 色欲天天婬色婬香影院| 好男人WWW免费高清视频在线| 中文字幕无码亚洲视频|