一、問題引入
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)行交互的嗡靡,獲取信息