DUBBO注冊發(fā)現(xiàn)源碼分析

首先附上我畫的兩張圖

(架構)


架構圖


原理圖

原理


總結:這篇文章,主要介紹的是dubbo服務的三個原理

a:解析服務:將配置好的文件(dubbo配置文件)解析成bean對象,依據(jù)bean對象生成URL

b:暴露服務:將解析出來的URL,根據(jù)協(xié)議頭,注冊到注冊中心并暴露服務

c:服務調用:根據(jù)url的協(xié)議頭,invoke實例,獲得服務


一解析服務:


1.讀取(如spring)配置文件,匹配名稱空間為dubbo 的配置,這些配置將會注入到相應的config里面

dubbo 的配置

2.使用handler(DubboNameSpaceHandler)類,調用DubboBeanDefinitionParse


DubboNameSpaceHandler

這個時候就開始配置config了,我們重點看上圖的ServiceBean


ServiceBean

這個Bean是對ServiceConfig 的一個擴展,而ServiceConfig里面定義了接口類型,接口實現(xiàn)類引用,服務名稱,方法配置 ,方法集合等 服務相關的配置.


ServiceConfig

而他的父類,則定義了基礎配置


接著說上面提到的利用DubboBeanDefinitionParse解析配置,轉化為Bean對象

DubboBeanDefinitionParse?

3. 將bean對象轉為為URL格式,bean對象的參數(shù)轉化為URL的參數(shù)


ServiceConfig

ReferenceConfig里面有一個創(chuàng)建proxy的方法

ReferenceConfig

這個方法里面會將bean封裝成一個URL對象(如果有,則包含了用戶指定的注冊地址)


同下文的暴露端口
需要暴露IP和端口

最后封裝到的是這個接口,使用了SPI

代理工廠

4.url會傳輸給Protocol,根據(jù)不同的協(xié)議頭來進行不同的暴露和引用

二 暴露服務



1.從ServiceConfig拿到了服務的實際類getInvoker方法,判斷暴露方式

ServiceConfig

2.如果本地暴露,協(xié)議頭為dubbo類型,適配到DubboProtocol的export()方法,暴露服務


DubboProtocol

3.如果是像注冊中心暴露服務,協(xié)議頭為register類型,適配到RegisterProtocol的export()方法,修改url后,調用DubboProtocol的export()方法,注冊到注冊中心,然后暴露服務


RegisterProtocol
上圖的解釋

3.初始化結束

三 調用服務




1.直接引用的(協(xié)議頭dubbo,只暴露端口的),通過ReferenceConfig解析URL.通過適配器找到DubboProtocol的refer()方法,


DubboProtocol,(invoke)

2.從注冊中心發(fā)現(xiàn)引用服務(頭為register),通過ReferenceConfig解析URL,通過適配器找到RegistryProtocol的refer()方法,獲取refer的參數(shù),查詢提供者;這個時候協(xié)議頭會變成dubbo,重復第1步流程.如果有多個提供者,則為偽裝成一個服務.

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市闷煤,隨后出現(xiàn)的幾起案子瓦阐,更是在濱河造成了極大的恐慌,老刑警劉巖朝蜘,帶你破解...
    沈念sama閱讀 211,042評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異涩金,居然都是意外死亡谱醇,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,996評論 2 384
  • 文/潘曉璐 我一進店門步做,熙熙樓的掌柜王于貴愁眉苦臉地迎上來副渴,“玉大人,你說我怎么就攤上這事全度≈缶纾” “怎么了?”我有些...
    開封第一講書人閱讀 156,674評論 0 345
  • 文/不壞的土叔 我叫張陵将鸵,是天一觀的道長勉盅。 經(jīng)常有香客問我,道長顶掉,這世上最難降的妖魔是什么草娜? 我笑而不...
    開封第一講書人閱讀 56,340評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮一喘,結果婚禮上驱还,老公的妹妹穿的比我還像新娘。我一直安慰自己凸克,他們只是感情好议蟆,可當我...
    茶點故事閱讀 65,404評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著萎战,像睡著了一般咐容。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上蚂维,一...
    開封第一講書人閱讀 49,749評論 1 289
  • 那天戳粒,我揣著相機與錄音路狮,去河邊找鬼。 笑死蔚约,一個胖子當著我的面吹牛奄妨,可吹牛的內容都是我干的。 我是一名探鬼主播苹祟,決...
    沈念sama閱讀 38,902評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼砸抛,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了树枫?” 一聲冷哼從身側響起直焙,我...
    開封第一講書人閱讀 37,662評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎砂轻,沒想到半個月后奔誓,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,110評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡搔涝,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年厨喂,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片庄呈。...
    茶點故事閱讀 38,577評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡杯聚,死狀恐怖,靈堂內的尸體忽然破棺而出抒痒,到底是詐尸還是另有隱情,我是刑警寧澤故响,帶...
    沈念sama閱讀 34,258評論 4 328
  • 正文 年R本政府宣布,位于F島的核電站颁独,受9級特大地震影響,放射性物質發(fā)生泄漏誓酒。R本人自食惡果不足惜樟蠕,卻給世界環(huán)境...
    茶點故事閱讀 39,848評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望靠柑。 院中可真熱鬧靡狞,春花似錦、人聲如沸梢杭。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,726評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽符衔。三九已至项戴,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背君躺。 一陣腳步聲響...
    開封第一講書人閱讀 31,952評論 1 264
  • 我被黑心中介騙來泰國打工谍珊, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人绊茧。 一個月前我還...
    沈念sama閱讀 46,271評論 2 360
  • 正文 我出身青樓华畏,卻偏偏與公主長得像,于是被迫代替她去往敵國和親厕九。 傳聞我的和親對象是個殘疾皇子穿香,可洞房花燭夜當晚...
    茶點故事閱讀 43,452評論 2 348

推薦閱讀更多精彩內容

  • Spring Cloud為開發(fā)人員提供了快速構建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務發(fā)現(xiàn)焙蚓,斷路器,智...
    卡卡羅2017閱讀 134,628評論 18 139
  • dubbo暴露服務有兩種情況萌京,一種是設置了延遲暴露(比如delay="5000"),另外一種是沒有設置延遲暴露或者...
    加大裝益達閱讀 21,257評論 5 36
  • 本文將詳細分析Dubbo的服務發(fā)布流程宏浩,建議結合文章Dubbo SPI 機制解析一起閱讀知残。 在開始分析之前,有必須...
    匠丶閱讀 4,080評論 0 6
  • 20170415 周六求妹,天氣晴好,大家相約去魯山西大河風景區(qū)制恍。三輛校車父能,百十號人,一路飛馳净神,將近三個小時的車程把我...
    張毛麗閱讀 469評論 1 1
  • 今天是練字的第80天何吝,正好2018年11月28日。以后的日子888~~一路發(fā)發(fā)發(fā)0拧!黔酥! 加入時間管理八匠,我已經(jīng)經(jīng)歷過...
    迎風奔跑2021閱讀 336評論 0 0