在認識Dubbo之前,先要認識RPC框架。RPC是什麼呢?
一、RPC
RPC【Remote Procedure Call】是指遠程過程調用,是一種進程間通信方式,他是一種技術的思想,而不是規範。它允許程序調用另一個地址空間(通常是共享網絡的另一臺機器上)的過程或函數,而不用程序員顯式編碼這個遠程調用的細節。
RPC調用流程
1)服務消費方(client)調用以本地調用方式調用服務;
2)client stub接收到調用後負責將方法、參數等組裝成能夠進行網絡傳輸的消息體;
3)client stub找到服務地址,並將消息發送到服務端;
4)server stub收到消息後進行解碼;
5)server stub根據解碼結果調用本地的服務;
6)本地服務執行並將結果返回給server stub;
7)server stub將返回結果打包成消息併發送至消費方;
8)client stub接收到消息,並進行解碼;
9)服務消費方得到最終結果。
RPC框架就是把從第2步到第8步分裝起來,對用戶來說是不可見的。
二、Dubbo概念
Dubbo是一款高性能、輕量級的開源Java RPC框架
特性
(1)面向接口代理的高性能RPC調用
(2)智能負載均衡
(3)服務自動註冊與發現
(4)高度可擴展能力
(5)運行期流量調度
(6)可視化的服務治理與運維
(1)服務提供者(Provider):暴露服務的服務提供方,服務提供者在啓動時,向註冊中心註冊自己提供的服務。
(2)服務消費者(Consumer): 調用遠程服務的服務消費方,服務消費者在啓動時,向註冊中心訂閱自己所需的服務,服務消費者,從提供者地址列表中,基於軟負載均衡算法,選一臺提供者進行調用,如果調用失敗,再選另一臺調用。
(3)註冊中心(Registry):註冊中心返回服務提供者地址列表給消費者,如果有變更,註冊中心將基於長連接推送變更數據給消費者
(4)監控中心(Monitor):服務消費者和提供者,在內存中累計調用次數和調用時間,定時每分鐘發送一次統計數據到監控中心
三、Dubbo的相關配置
1、配置文件的生效優先等級
(1)JVM 啓動 -D 參數優先,這樣可以使用戶在部署和啓動時進行參數重寫,比如在啓動時需改變協議的端口。
(2)XML 次之,如果在 XML 中有配置,則 dubbo.properties 中的相應配置項無效。
(3)Properties 最後,相當於缺省值,只有 XML 沒有配置時,dubbo.properties 的相應配置項纔會生效,通常用於共享公共配置,比如應用名。
2、重試次數 retries
失敗自動切換,當出現失敗,重試其它服務器,但重試會帶來更長延遲
(1)用法1
<dubbo:service retries="2" />
(2)用法2
<dubbo:reference retries="2" />
(3)用法3
<dubbo:reference>
<dubbo:method name="findFoo" retries="2" />
</dubbo:reference>
3、超時時間 timeout
服務端
(1)全局超時配置
<dubbo:provider timeout="5000" />
(2)指定接口以及特定方法超時配置
<dubbo:provider interface="com.foo.BarService" timeout="2000">
<dubbo:method name="sayHello" timeout="3000" />
</dubbo:provider>
消費端
(1)全局超時配置
<dubbo:consumer timeout="5000" />
(2)指定接口以及特定方法超時配置
<dubbo:reference interface="com.foo.BarService" timeout="2000">
<dubbo:method name="sayHello" timeout="3000" />
</dubbo:reference>
4、多版本
當一個接口實現,出現不兼容升級時,可以用版本號過渡,版本號不同的服務相互間不引用
可以按照以下的步驟進行版本遷移:
(1)在低壓力時間段,先升級一半提供者爲新版本
(2)再將所有消費者升級爲新版本
(3)然後將剩下的一半提供者升級爲新版本
老版本服務提供者配置:
<dubbo:service interface="com.foo.BarService" version="1.0.0" />
新版本服務提供者配置:
<dubbo:service interface="com.foo.BarService" version="2.0.0" />
老版本服務消費者配置:
<dubbo:reference id="barService" interface="com.foo.BarService" version="1.0.0" />
新版本服務消費者配置:
<dubbo:reference id="barService" interface="com.foo.BarService" version="2.0.0" />
四、Dubbo的安裝
參考博客地址:
https://blog.csdn.net/cxh6863/article/details/102874400
五、Dubbo與Springboot的整合
參考博客地址
https://blog.csdn.net/cxh6863/article/details/106003740