Java中的RPC框架Dubbo原理和機制詳解
1. Dubbo核心功能
Dubbo主要提供了3大核心功能:面向接口的遠程方法調(diào)用,智能容錯和負載均衡,以及服務(wù)自動注冊和發(fā)現(xiàn)。
1)遠程方法調(diào)用
網(wǎng)絡(luò)通信框架,提供對多種NIO框架抽象封裝,包括“同步轉(zhuǎn)異步”和“請求-響應(yīng)”模式的信息交換方式。
2)智能容錯和負載均衡
提供基于接口方法的透明遠程過程調(diào)用,包括多協(xié)議支持,以及軟負載均衡,失敗容錯,地址路由,動態(tài)配置等集群支持。
3)服務(wù)注冊和發(fā)現(xiàn)
服務(wù)注冊,基于注冊中心目錄服務(wù),使服務(wù)消費方能動態(tài)的查找服務(wù)提供方,使地址透明,使服務(wù)提供方可以平滑增加或減少機器。
2. Dubbo核心組件
主要包含如下幾個核心組件:
1)注冊中心(registry)
生產(chǎn)者在此注冊并發(fā)布內(nèi)容,消費者在此訂閱并接收發(fā)布的內(nèi)容。
2)消費者(consumer)
客戶端,從注冊中心獲取到方法,可以調(diào)用生產(chǎn)者中的方法。
3)生產(chǎn)者(provider)
服務(wù)端,生產(chǎn)內(nèi)容,生產(chǎn)前需要依賴容器(先啟動容器)。
4)容器(container)
生產(chǎn)者在啟動執(zhí)行的時候,必須依賴容器才能正常啟動(默認依賴的是spring容器),
5)監(jiān)控(Monitor)
統(tǒng)計服務(wù)的調(diào)用次數(shù)與時間等。
3. Dubbo的架構(gòu)設(shè)計
Dubbo整體架構(gòu)如下圖所示:
圖中左邊淡藍背景的為服務(wù)消費方使用的接口,右邊淡綠色背景的為服務(wù)提供方使用的接口, 位于中軸線上的為雙方都用到的接口。
Dubbo框架設(shè)計一共劃分了10個層:
1. 服務(wù)接口層(Service)
該層是與實際業(yè)務(wù)邏輯相關(guān)的,根據(jù)服務(wù)提供方和服務(wù)消費方的業(yè)務(wù)設(shè)計對應(yīng)的接口和實現(xiàn)。
2. 配置層(Config)
對外配置接口,以ServiceConfig和ReferenceConfig為中心,可以直接new配置類,也可以通過spring解析配置生成配置類。
3.服務(wù)代理層(Proxy)
服務(wù)接口透明代理,生成服務(wù)的客戶端Stub和服務(wù)器端Skeleton,以ServiceProxy為中心,擴展接口為ProxyFactory。
4.服務(wù)注冊層(Registry)
封裝服務(wù)地址的注冊與發(fā)現(xiàn),以服務(wù)URL為中心,擴展接口為RegistryFactory、Registry和RegistryService。可能沒有服務(wù)注冊中心,此時服務(wù)提供方直接暴露服務(wù)。
5.集群層(Cluster)
封裝多個提供者的路由及負載均衡,并橋接注冊中心,以Invoker為中心,擴展接口為Cluster、Directory、Router和LoadBalance。將多個服務(wù)提供方組合為一個服務(wù)提供方,實現(xiàn)對服務(wù)消費方來透明,只需要與一個服務(wù)提供方進行交互。
6.監(jiān)控層(Monitor)
RPC調(diào)用次數(shù)和調(diào)用時間監(jiān)控,以Statistics為中心,擴展接口為MonitorFactory、Monitor和MonitorService。
7.遠程調(diào)用層(Protocol)
封將RPC調(diào)用,以Invocation和Result為中心,擴展接口為Protocol、Invoker和Exporter。Protocol是服務(wù)域,它是Invoker暴露和引用的主功能入口,它負責(zé)Invoker的生命周期管理。Invoker是實體域,它是Dubbo的核心模型,其它模型都向它靠擾,或轉(zhuǎn)換成它,它代表一個可執(zhí)行體,可向它發(fā)起invoke調(diào)用,它有可能是一個本地的實現(xiàn),也可能是一個遠程的實現(xiàn),也可能一個集群實現(xiàn)。
8. 信息交換層(Exchange)
封裝請求響應(yīng)模式,同步轉(zhuǎn)異步,以Request和Response為中心,擴展接口為Exchanger、ExchangeChannel、ExchangeClient和ExchangeServer。
9.網(wǎng)絡(luò)傳輸層(Transport)
抽象mina和netty為統(tǒng)一接口,以Message為中心,擴展接口為Channel、Transporter、Client、Server和Codec。
10.數(shù)據(jù)序列化層(Serialize)
可復(fù)用的一些工具,擴展接口為Serialization、 ObjectInput、ObjectOutput和ThreadPool。
4. Dubbo調(diào)用流程
對照上面的整體架構(gòu)圖,大致分為以下8大步驟:
1、服務(wù)提供者啟動,開啟Netty服務(wù),創(chuàng)建Zookeeper客戶端,向注冊中心注冊服務(wù);
2、服務(wù)消費者啟動,通過Zookeeper向注冊中心獲取服務(wù)提供者列表,與服務(wù)提供者通過Netty建立長連接;
3、服務(wù)消費者通過接口開始遠程調(diào)用服務(wù),ProxyFactory通過初始化Proxy對象,Proxy通過創(chuàng)建動態(tài)代理對象;
4、動態(tài)代理對象通過invoke方法,層層包裝生成一個Invoker對象,該對象包含了代理對象;
5、Invoker通過路由,負載均衡選擇了一個最合適的服務(wù)提供者,在通過加入各種過濾器,協(xié)議層包裝生成一個新的DubboInvoker對象;
6、再通過交換成將DubboInvoker對象包裝成一個Reuqest對象,該對象通過序列化通過NettyClient傳輸?shù)椒?wù)提供者的NettyServer端;
7、到了服務(wù)提供者這邊,再通過反序列化、協(xié)議解密等操作生成一個DubboExporter對象,再層層傳遞處理,會生成一個服務(wù)提供端的Invoker對象;
8、這個Invoker對象會調(diào)用本地服務(wù),獲得結(jié)果再通過層層回調(diào)返回到服務(wù)消費者,服務(wù)消費者拿到結(jié)果后,再解析獲得最終結(jié)果。
到此這篇關(guān)于Java中的RPC框架Dubbo原理和機制詳解的文章就介紹到這了,更多相關(guān)Dubbo原理和機制內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java根據(jù)日期截取字符串的多種實現(xiàn)方法
在實際開發(fā)中,我們經(jīng)常會遇到需要根據(jù)日期來截取字符串的需求,例如從文件名中提取日期信息,Java 提供了多種方法來實現(xiàn)根據(jù)日期來截取字符串的功能,本文將給大家介紹了Java根據(jù)日期截取字符串的多種實現(xiàn)方法,需要的朋友可以參考下2024-11-11springboot項目不加端口號也可以訪問項目的方法步驟分析
這篇文章主要介紹了springboot項目不加端口號也可以訪問項目的方法,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-04-04Java實現(xiàn)規(guī)則幾何圖形的繪制與周長面積計算詳解
隨著計算機的發(fā)展,人們對圖形的計算要求會越來越高。在各行各業(yè)中的計算人員會對圖形的計算要有便利的要求,規(guī)則幾何圖形問題求解程序應(yīng)運而生!本文將用Java編寫一個程序,可以實現(xiàn)規(guī)則幾何圖形的繪制與周長面積計算,感興趣的可以了解一下2022-07-07SpringBoot整合EasyExcel實現(xiàn)導(dǎo)入導(dǎo)出數(shù)據(jù)
這篇文章主要為大家詳細介紹了如何使用Vue、SpringBoot和EasyExcel實現(xiàn)導(dǎo)入導(dǎo)出數(shù)據(jù)功能,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2022-05-05兩種Spring服務(wù)關(guān)閉時對象銷毀的實現(xiàn)方法
spring提供了兩種方式用于實現(xiàn)對象銷毀時去執(zhí)行的操作,本文主要為大家詳細介紹了這兩種方式的具體實現(xiàn),文中的示例代碼講解詳細,希望對大家有所幫助2023-04-04