撥云見日之dubbo服務(wù)導(dǎo)出

一、問題引入

1.? ?當(dāng)我們寫下<dubbo:service interface="MyService" ref="myServiceImpl" protocol="dubbo" registry="zookeeper"/> 時侍咱,是什么時候執(zhí)行的弛饭?

2.? ?服務(wù)的暴露,為何暴露留特,何為暴露纠脾,到底暴露到哪里去了,為什么需要本地暴露蜕青?

3.? ?導(dǎo)出服務(wù)苟蹈,是如何注冊到注冊中心的?

4.? ?一個導(dǎo)出的服務(wù)是如何跟客戶端高效溝通的右核?


二慧脱、總體結(jié)構(gòu)

1. 名詞解釋

Exporter和Invoker

Dubbo 服務(wù)暴露時,首先會創(chuàng)建一個 DubboExporter贺喝,然后再通過 netty 開啟服務(wù)端口監(jiān)聽菱鸥。?DubboExporter 的作用是緩存 Invoker,方便后續(xù)操作獲取 Invoker躏鱼。其中最重要的操作就是: Provider 接收到 Request 請求后氮采,獲取到對應(yīng)的 Invoker,然后執(zhí)行 Invoker染苛。

URL

沒有注冊中心:dubbo://service-host/com.foo.FooService?version=1.0.0

有注冊中心: registry://registry-host/org.apache.dubbo.registry.RegistryService?export=URL.encode("dubbo://service-host/com.foo.FooService?version=1.0.0")


2. 總體步驟

? ? ? 第一部分是前置工作鹊漠,主要用于檢查參數(shù),組裝 URL茶行。

? ? ? 第二部分是導(dǎo)出服務(wù)躯概,包含導(dǎo)出服務(wù)到本地 (JVM),和導(dǎo)出服務(wù)到遠(yuǎn)程兩個過程畔师。

? ? ? 第三部分是向注冊中心注冊服務(wù)娶靡,用于服務(wù)發(fā)現(xiàn)。

三看锉、核心思想

1.??服務(wù)提供者暴露一個服務(wù)的詳細(xì)過程


2.??Invoker


3. 服務(wù)暴露時序圖


四姿锭、源碼解讀

1. 獲取invoker


準(zhǔn)備工作做完后ProxyFactory上場,dubbo中有兩種代理方式伯铣,JDK代理和Javassist代理艾凯,默認(rèn)使用Javassist代理,Proxy代理類根據(jù)dubbo配置信息獲取到接口信息懂傀、通過動態(tài)代理方式將接口的所有方法交給Proxy代理類進(jìn)行代理趾诗,并封裝進(jìn)Invoker里面。

將所有需要暴露的service封裝的Invoker組成一個list傳給信息交換層提供給消費方進(jìn)行調(diào)用。

代理模式的經(jīng)典應(yīng)用恃泪。

2. export?


Dubbo 服務(wù)暴露時郑兴,首先會創(chuàng)建一個 DubboExporter,然后再通過 netty 開啟服務(wù)端口監(jiān)聽贝乎。?DubboExporter 的作用是緩存 Invoker情连,方便后續(xù)操作獲取 Invoker。其中最重要的操作就是: Provider 接收到 Request 請求后览效,獲取到對應(yīng)的 Invoker却舀,然后執(zhí)行 Invoker。

在服務(wù)暴露時锤灿,有兩種情況:不使用注冊中心:直接暴露對應(yīng)協(xié)議的服務(wù)挽拔,引用服務(wù)時只能通過直連方式引用.

? ? ? ? ? ? ? ? ? ? ? ? ?使用注冊中心:暴露對應(yīng)協(xié)議的服務(wù)后,會將服務(wù)節(jié)點注冊到注冊中心但校,引用服務(wù)時可以通過注冊中心動態(tài)獲取服務(wù)提供者列表螃诅,也可以通過直連方式引用

export方法其實干了兩件事:

1、將Invoker export出去状囱,然后創(chuàng)建 DubboExporter實例并存儲在 exporterMap 里术裸,Exporter其實就是一個存儲了Invoker實例及其他各種信息的容器,用于之后獲取Invoker用亭枷。

2袭艺、打開服務(wù)端口,并注冊ExchangeHandler叨粘,用于后續(xù)響應(yīng)客戶端網(wǎng)絡(luò)請求猾编。


3.?Registry

getRegistry()?方法根據(jù)注冊中心類型(默認(rèn)?Zookeeper)獲取注冊中心客戶端,由注冊中心客戶端實例來進(jìn)行真正的服務(wù)注冊宣鄙。

注冊中心客戶端將節(jié)點注冊到注冊中心袍镀,同時訂閱對應(yīng)的?override?數(shù)據(jù)默蚌,實時監(jiān)聽服務(wù)的屬性變動實現(xiàn)動態(tài)配置功能冻晤。

模板模式的經(jīng)典應(yīng)用

五、撥開云霧

? ? ? ? 任何技術(shù)原理绸吸,在生活中都有參照鼻弧,八卦蛇形,日月乾坤锦茁,學(xué)會獨立思考攘轩,認(rèn)真觀察,處處皆學(xué)問码俩。

? ? ? ? ??


六度帮、看清本質(zhì)

1. 服務(wù)暴露很簡單,只做了兩件事

1. 消費端執(zhí)行DemoService service的具體方法,實際是執(zhí)行代理實現(xiàn)類的對應(yīng)方法笨篷,代理類的方法執(zhí)行實際是通過invoker來執(zhí)行瞳秽,invoker執(zhí)行的時候?qū)嶋H就是通過網(wǎng)絡(luò)通信將請求發(fā)送給服務(wù)端

2、服務(wù)端接收消息進(jìn)行解碼率翅,得到請求的信息练俐,根據(jù)請求信息得到Exporter對象,根據(jù)Exporter對象可以獲取Invoker對象冕臭,然后通過Invoker來執(zhí)行具體的方法(這個Invoker和消費端的Invoker不是同一個實現(xiàn))

2. 服務(wù)注冊很簡單腺晾,只做了一件事

1. 把組裝的url,在zk中創(chuàng)建一個節(jié)點辜贵,讓客戶端能訂閱

3. 服務(wù)暴露暴露了啥

暴露服務(wù)的時候悯蝉,IP,端口念颈,服務(wù)名稱泉粉,方法名稱,是要放入到注冊中心的榴芳。因為最終服務(wù)的引用者是和注冊中心進(jìn)行交互的嗡靡,獲取信息

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市窟感,隨后出現(xiàn)的幾起案子讨彼,更是在濱河造成了極大的恐慌,老刑警劉巖柿祈,帶你破解...
    沈念sama閱讀 212,454評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件哈误,死亡現(xiàn)場離奇詭異,居然都是意外死亡躏嚎,警方通過查閱死者的電腦和手機蜜自,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,553評論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來卢佣,“玉大人重荠,你說我怎么就攤上這事⌒椴瑁” “怎么了戈鲁?”我有些...
    開封第一講書人閱讀 157,921評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長嘹叫。 經(jīng)常有香客問我婆殿,道長,這世上最難降的妖魔是什么罩扇? 我笑而不...
    開封第一講書人閱讀 56,648評論 1 284
  • 正文 為了忘掉前任婆芦,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘消约。我一直安慰自己癌压,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 65,770評論 6 386
  • 文/花漫 我一把揭開白布荆陆。 她就那樣靜靜地躺著滩届,像睡著了一般。 火紅的嫁衣襯著肌膚如雪被啼。 梳的紋絲不亂的頭發(fā)上帜消,一...
    開封第一講書人閱讀 49,950評論 1 291
  • 那天,我揣著相機與錄音浓体,去河邊找鬼泡挺。 笑死,一個胖子當(dāng)著我的面吹牛命浴,可吹牛的內(nèi)容都是我干的娄猫。 我是一名探鬼主播,決...
    沈念sama閱讀 39,090評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼生闲,長吁一口氣:“原來是場噩夢啊……” “哼媳溺!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起碍讯,我...
    開封第一講書人閱讀 37,817評論 0 268
  • 序言:老撾萬榮一對情侶失蹤悬蔽,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后捉兴,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體蝎困,經(jīng)...
    沈念sama閱讀 44,275評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,592評論 2 327
  • 正文 我和宋清朗相戀三年倍啥,在試婚紗的時候發(fā)現(xiàn)自己被綠了禾乘。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,724評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡虽缕,死狀恐怖始藕,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情彼宠,我是刑警寧澤鳄虱,帶...
    沈念sama閱讀 34,409評論 4 333
  • 正文 年R本政府宣布弟塞,位于F島的核電站凭峡,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏决记。R本人自食惡果不足惜摧冀,卻給世界環(huán)境...
    茶點故事閱讀 40,052評論 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧索昂,春花似錦建车、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,815評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至康谆,卻和暖如春领斥,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背沃暗。 一陣腳步聲響...
    開封第一講書人閱讀 32,043評論 1 266
  • 我被黑心中介騙來泰國打工月洛, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人孽锥。 一個月前我還...
    沈念sama閱讀 46,503評論 2 361
  • 正文 我出身青樓嚼黔,卻偏偏與公主長得像,于是被迫代替她去往敵國和親惜辑。 傳聞我的和親對象是個殘疾皇子唬涧,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,627評論 2 350

推薦閱讀更多精彩內(nèi)容