【中間件】Dubbo是什麼呢,又該怎麼用呢

在認識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

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章