dubbo原理和機(jī)制是什么
2023-05-04 14:07:03 閱讀(283)
dubbo原理深度解析?
dubbo原理和機(jī)制: Dubbo是一個(gè)高性能優(yōu)秀的服務(wù)框架,它使得應(yīng)用可通過(guò)高性能的 RPC 實(shí)現(xiàn)服務(wù)的輸出和輸入功能,可以和Spring框架無(wú)縫集成。 Dubbo是一款高性能、輕量級(jí)的開源Java RPC框架。 它提供了三大核心能力: 1、面向接口的遠(yuǎn)程方法調(diào)用; 2、智能容錯(cuò)和負(fù)載均衡; 3、服務(wù)自動(dòng)注冊(cè)和發(fā)現(xiàn)。 注冊(cè)中心負(fù)責(zé)服務(wù)地址的注冊(cè)與查找,相當(dāng)于目錄服務(wù),服務(wù)提供者和消費(fèi)者只在啟動(dòng)時(shí)與注冊(cè)中心交互,注冊(cè)中心不轉(zhuǎn)發(fā)請(qǐng)求,壓力較小。 監(jiān)控中心負(fù)責(zé)統(tǒng)計(jì)各服務(wù)調(diào)用次數(shù),調(diào)用時(shí)間等,統(tǒng)計(jì)先在內(nèi)存匯總后每分鐘一次發(fā)送到監(jiān)控中心服務(wù)器,并以報(bào)表展示。 服務(wù)提供者向注冊(cè)中心注冊(cè)其提供的服務(wù),并匯報(bào)調(diào)用時(shí)間到監(jiān)控中心,此時(shí)間不包含網(wǎng)絡(luò)開銷。 服務(wù)消費(fèi)者向注冊(cè)中心獲取服務(wù)提供者地址列表,并根據(jù)負(fù)載算法直接調(diào)用提供者,同時(shí)匯報(bào)調(diào)用時(shí)間到監(jiān)控中心,此時(shí)間包含網(wǎng)絡(luò)開銷。
dubbo服務(wù)器之間通過(guò)什么來(lái)調(diào)用?
原理:首先有個(gè)服務(wù)器,提供注冊(cè)服務(wù),稱之為注冊(cè)中心。 服務(wù)提供方連接注冊(cè)中心,將對(duì)應(yīng)的服務(wù)配置到注冊(cè)中心中。服務(wù)消費(fèi)方連接到注冊(cè)中心,通過(guò)注冊(cè)中心,調(diào)用服務(wù)提供方提供的方法或服務(wù)。
dubbo線程池原理及源碼?
DUBBO提供五種線程模型 all 所有消息都派發(fā)到業(yè)務(wù)線程池,包括請(qǐng)求,響應(yīng),連接事件,斷開事件,心跳 direct 所有消息都不派發(fā)到業(yè)務(wù)線程池,全部在IO線程直接執(zhí)行 message 只有請(qǐng)求響應(yīng)消息派發(fā)到業(yè)務(wù)線程池,其它連接斷開事件,心跳等消息直接在IO線程執(zhí)行 execution 只有請(qǐng)求消息派發(fā)到業(yè)務(wù)線程池,響應(yīng)和其它連接斷開事件,心跳等消息直接在IO線程執(zhí)行 connection 在IO線程上將連接斷開事件放入隊(duì)列,有序逐個(gè)執(zhí)行,其它消息派發(fā)到業(yè)務(wù)線程池
dubbo隱式傳參實(shí)現(xiàn)原理?
1) 遠(yuǎn)程通訊協(xié)議基本原理 a) 網(wǎng)絡(luò)通信:將二進(jìn)制流從一臺(tái)計(jì)算機(jī)傳輸?shù)搅硗庖慌_(tái)計(jì)算機(jī),基于傳輸協(xié)議和網(wǎng)絡(luò)IO來(lái)實(shí)現(xiàn) b) 傳輸協(xié)議有 http 、 tcp 、 udp, 都是在基于 Socket 概念擴(kuò)展而來(lái) c) 網(wǎng)絡(luò)IO,主要有 bio 、 nio 、 aio, 所有的分布式應(yīng)用通訊都基于這個(gè)原理而實(shí)現(xiàn)
dubbo原理?
dubbo原理如下: 第一層:service層,接口層,給服務(wù)提供者和消費(fèi)者來(lái)實(shí)現(xiàn)的。 第二層:config層,配置層,主要是對(duì)dubbo進(jìn)行各種配置的。 第三層:proxy層,服務(wù)代理層,透明生成客戶端的stub和服務(wù)單的skeleton。 第四層:registry層,服務(wù)注冊(cè)層,負(fù)責(zé)服務(wù)的注冊(cè)與發(fā)現(xiàn)。 第五層:cluster層,集群層,封裝多個(gè)服務(wù)提供者的路由以及負(fù)載均衡,將多個(gè)實(shí)例組合成一個(gè)服務(wù)。 第六層:monitor層,監(jiān)控層,對(duì)rpc接口的調(diào)用次數(shù)和調(diào)用時(shí)間進(jìn)行監(jiān)控。 第七層:protocol層,遠(yuǎn)程調(diào)用層,封裝rpc調(diào)用。 第八層:exchange層,信息交換層,封裝請(qǐng)求響應(yīng)模式,同步轉(zhuǎn)異步。 第九層:transport層,網(wǎng)絡(luò)傳輸層,抽象mina和netty為統(tǒng)一接口。 第十層:serialize層,數(shù)據(jù)序列化層。
dubbo異步轉(zhuǎn)同步原理?
Dubbo是一款開源的RPC中間件框架,底層數(shù)據(jù)傳輸默認(rèn)使用的Netty,那么請(qǐng)求的處理理論上是異步的。 異步轉(zhuǎn)同步原理: 1、調(diào)用方請(qǐng)求遠(yuǎn)程服務(wù)之后,需要等待結(jié)果,此刻,請(qǐng)求線程應(yīng)該阻塞。 2、遠(yuǎn)程服務(wù)返回結(jié)果后,喚醒請(qǐng)求線程,調(diào)用方得到結(jié)果: Dubbo異步轉(zhuǎn)同步,核心類是DefaultFuture,核心方法是get(),received(Channel channel, Response response)。
dubbo調(diào)用流程原理?
步驟 1/7分步閱讀 服務(wù)容器Container 負(fù)責(zé)啟動(dòng)加載運(yùn)行服務(wù)提供者Provider。根據(jù)Provider配置的文件根據(jù)協(xié)議發(fā)布服務(wù) , 完成服務(wù)的初始化. 2/7 Provider在啟動(dòng)時(shí),根據(jù)配置中的Registry地址連接Registry,將Provider的服務(wù)信息發(fā)布到Registry,在Registry注冊(cè)自己提供的服務(wù)。 3/7 Consumer在啟動(dòng)時(shí),根據(jù)消費(fèi)者XML配置文件中的服務(wù)引用信息,連接到Registry,向Registry訂閱自己所需的服務(wù)。 4/7 Registry根據(jù)服務(wù)訂閱關(guān)系,返回Provider地址列表給Consumer,如果有變更,Registry會(huì)推送最新的服務(wù)地址信息給Consumer。 5/7 Consumer調(diào)用遠(yuǎn)程服務(wù)時(shí),會(huì)根據(jù)路由策略,先從緩存的Provider地址列表中選擇一臺(tái)進(jìn)行,跨進(jìn)程調(diào)用服務(wù),假如調(diào)用失敗,再重新選另一臺(tái)調(diào)用。 6/7 服務(wù)Provider和Consumer,會(huì)在內(nèi)存中記錄調(diào)用次數(shù)和調(diào)用時(shí)間,每分鐘發(fā)送一次統(tǒng)計(jì)數(shù)據(jù)到Monitor。 7/7 這就是整個(gè)完整的Dubbo調(diào)用過(guò)程和原理
dubbo工作原理和機(jī)制?
Dubbo 框架是用來(lái)處理分布式系統(tǒng)中,服務(wù)發(fā)現(xiàn)與注冊(cè)以及調(diào)用問(wèn)題的,并且管理調(diào)用過(guò)程。 各個(gè)部分整體機(jī)制: 1、提供者暴露服務(wù)的整體機(jī)制 2.注冊(cè)中心 3.服務(wù)消費(fèi)者 4.Dubbo 集群容錯(cuò) 5.Dubbo 遠(yuǎn)程調(diào)用 dubbo原理和機(jī)制:應(yīng)用可通過(guò)高性能的 RPC 實(shí)現(xiàn)服務(wù)的輸出和輸入功能,可以和Spring框架無(wú)縫集成。
未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明出處