非常全面 Dubbo 原理和機制詳解


非常全面 Dubbo 原理和機制詳解

文章插圖
Dubbo 是一款Java RPC框架,致力于提供高性能的 RPC 遠程服務調用方案 。作為主流的微服務框架之一,Dubbo 為開發人員帶來了非常多的便利 。
大家好,我是 mikechen,專注分享「互聯網大廠架構技術」~
本文 , 我重點詳解 Dubbo 的原理機制 @mikechen
目錄
  • Dubbo核心功能
  • Dubbo核心組件
  • Dubbo的架構設計
  • Dubbo調用流程
Dubbo核心功能Dubbo主要提供了3大核心功能:面向接口的遠程方法調用,智能容錯和負載均衡,以及服務自動注冊和發現 。
 1)遠程方法調用
網絡通信框架 , 提供對多種NIO框架抽象封裝,包括“同步轉異步”和“請求-響應”模式的信息交換方式 。
 2)智能容錯和負載均衡
提供基于接口方法的透明遠程過程調用,包括多協議支持,以及軟負載均衡,失敗容錯,地址路由 , 動態配置等集群支持 。
3)服務注冊和發現
服務注冊,基于注冊中心目錄服務,使服務消費方能動態的查找服務提供方,使地址透明,使服務提供方可以平滑增加或減少機器 。
Dubbo核心組件Dubbo角色,主要包含如下幾個核心組件:
【非常全面 Dubbo 原理和機制詳解】
非常全面 Dubbo 原理和機制詳解

文章插圖
1)注冊中心(registry)
生產者在此注冊并發布內容,消費者在此訂閱并接收發布的內容 。
2)消費者(consumer)
客戶端,從注冊中心獲取到方法,可以調用生產者中的方法 。
3)生產者(provider)
服務端,生產內容,生產前需要依賴容器(先啟動容器) 。
4)容器(container)
生產者在啟動執行的時候,必須依賴容器才能正常啟動(默認依賴的是spring容器),
5)監控(Monitor)
統計服務的調用次數與時間等 。
Dubbo的架構設計Dubbo整體架構如下圖所示:
非常全面 Dubbo 原理和機制詳解

文章插圖
圖中左邊淡藍背景的為服務消費方使用的接口,右邊淡綠色背景的為服務提供方使用的接口 ,  位于中軸線上的為雙方都用到的接口 。
Dubbo框架設計一共劃分了10個層:
1. 服務接口層(Service)
該層是與實際業務邏輯相關的,根據服務提供方和服務消費方的業務設計對應的接口和實現 。
2. 配置層(Config)
對外配置接口,以ServiceConfig和ReferenceConfig為中心,可以直接new配置類,也可以通過spring解析配置生成配置類 。
 3.服務代理層(Proxy)
服務接口透明代理,生成服務的客戶端Stub和服務器端Skeleton,以ServiceProxy為中心,擴展接口為ProxyFactory 。
 4.服務注冊層(Registry)
封裝服務地址的注冊與發現,以服務URL為中心,擴展接口為RegistryFactory、Registry和RegistryService ??赡軟]有服務注冊中心 , 此時服務提供方直接暴露服務 。
 5.集群層(Cluster)
封裝多個提供者的路由及負載均衡,并橋接注冊中心,以Invoker為中心,擴展接口為Cluster、Directory、Router和LoadBalance 。將多個服務提供方組合為一個服務提供方 , 實現對服務消費方來透明,只需要與一個服務提供方進行交互 。
 6.監控層(Monitor)
RPC調用次數和調用時間監控,以Statistics為中心 , 擴展接口為MonitorFactory、Monitor和MonitorService 。
 7.遠程調用層(Protocol)
封將RPC調用,以Invocation和Result為中心,擴展接口為Protocol、Invoker和Exporter 。Protocol是服務域,它是Invoker暴露和引用的主功能入口,它負責Invoker的生命周期管理 。Invoker是實體域,它是Dubbo的核心模型,其它模型都向它靠擾,或轉換成它,它代表一個可執行體,可向它發起invoke調用,它有可能是一個本地的實現 , 也可能是一個遠程的實現,也可能一個集群實現 。
8. 信息交換層(Exchange)
封裝請求響應模式,同步轉異步 , 以Request和Response為中心,擴展接口為Exchanger、ExchangeChannel、ExchangeClient和ExchangeServer 。
 9.網絡傳輸層(Transport)
抽象mina和netty為統一接口,以Message為中心,擴展接口為Channel、Transporter、Client、Server和Codec 。
10.數據序列化層(Serialize)
可復用的一些工具,擴展接口為Serialization、 ObjectInput、ObjectOutput和ThreadPool 。
Dubbo調用流程

推薦閱讀