Dubbo學習小記

来源:http://www.cnblogs.com/xrq730/archive/2016/03/27/5316805.html
-Advertisement-
Play Games

前言 周一入職的新公司,到了公司第一件事自然是要熟悉新公司使用的各種技術,搭建本地的環境。 熟悉新公司技術的過程中,首先就是Maven,這個前面已經寫過文章了,然後就是Dubbo 公司的服務都是通過Dubbo來治理的。其實之前我就對SOA、RPC等分散式服務的概念有所瞭解,Dubbo也多多少少知道一 ...


前言

周一入職的新公司,到了公司第一件事自然是要熟悉新公司使用的各種技術,搭建本地的環境。

熟悉新公司技術的過程中,首先就是Maven,這個前面已經寫過文章了,然後就是Dubbo----公司的服務都是通過Dubbo來治理的。其實之前我就對SOA、RPC等分散式服務的概念有所瞭解,Dubbo也多多少少知道一些,不過能親身使用那是再好不過的了。

此文就對我的Dubbo學習做一個小的總結,基本我總結的這些內容對於入門應該是足夠了。關於Dubbo的更詳細信息,阿裡有專門出手冊,手冊地址為http://dubbo.io/User+Guide-zh.htm,本文也只是對手冊的重點進行一些提煉而已(看過就知道了,這篇手冊實在是太龐大了),要進一步地瞭解Dubbo的朋友們還是應當去看Dubbo的官方手冊。

 

Dubbo是什麼

Dubbo是一個分散式服務框架,致力於提供高性能和透明化的RPC遠程服務調用方案,以及SOA服務治理方案。其核心部分包括:

  • 遠程通訊:提供對多種基於長連接的NIO框架抽象封裝,包括多種線程模型、序列化、"請求-響應"模式的信息交換方案
  • 集群容錯:提供基於藉口方法的透明遠程過程調用,包括多協議支持、軟負載均衡、失敗容錯、地址路由、動態配置等集群支持
  • 自動發現:基於註冊中心目錄服務,使服務消費方能動態地查找服務提供方,使地址透明,使服務提供方可以平滑增加或減少機器

 

Dubbo能做什麼

Dubbo功能強大,總結下來,它大致可以做以下幾件事:

  • 透明化的遠程方法調用,就像調用本地方法一樣調用遠程方法,只需要簡單配置,沒有任何API侵入
  • 軟負載均衡及容錯機制,可在內網替代F5等硬體負載均衡器,降低成本、減少多拿點
  • 服務自動註冊與發現,不再需要寫死服務提供方地址,註冊中心基於介面名查詢服務提供者的IP地址,並且能夠平滑添加或刪除服務提供者

 

Dubbo架構圖

這是最重要的,理解Dubbo的架構圖是理解Dubbo的第一步,我從Dubbo官網手冊上截了一下Dubbo架構圖:

 

在接下來的講解之前,說明一個概念:所謂SOA也好,分散式服務框架也好,不是服務消費者從中間件(一般都是Zookeeper)上去拿數據,而是服務消費者從中間件上拿到可用的服務生產者的集群地址,再從集群地址中選出一個進行直連

接下來認識一下圖中的結點:

  • Provider:暴露服務的服務提供方,或者直白點說就是服務生產者
  • Consumer:調用遠程服務的服務消費方,也就是服務消費者
  • Registry:服務註冊與發現的註冊中心
  • Monitor:統計服務的調用次數和調用時間的監控中心
  • Container:服務(生產者)運行容器

圖中已經有了調用步驟了,接著對步驟進行說明:

  • 0:服務容器負責啟動、載入、運行服務提供者(生產者)
  • 1:服務提供者(生產者)在啟動時,向註冊中心註冊自己提供的服務
  • 2:服務消費者在啟動時,向註冊中心訂閱自己所需的服務
  • 3:註冊中心返回服務提供者地址列表給消費者,如果有變更,註冊中細膩將基於長連接推送變更數據給消費者
  • 4:服務消費者從服務生產者地址列表中,基於軟負載均衡演算法,選擇一臺提供者(生產者)進行調用,如果調用失敗,再選另一臺調用
  • 5:服務消費者和提供者(生產者),在記憶體中累計調用次數和調用時間,定時每分鐘發送一次統計數據到監控中心

 

Dubbo用法

Dubbo採用全Spring配置方式,透明化接入應用,對應用沒有任何API侵入(這句話的意思是應用程式不會、不需要手動調用Dubbo的任何類和任何介面),只需用Spring載入Dubbo的配置即可(意思是對Dubbo的使用只需要寫Spring配置文件或註解),Dubbo基於Spring的Schema擴展進行載入。

如果不想使用Spring配置,而希望通過API的方式進行調用,可以自己看一下官方手冊Dubbo API配置,但是,這種做法十分不推薦。

下麵簡單說明一下Dubbo的用法,首先要定義服務生產者的介面及其實現,那麼定義一個介面(該介面需要單獨打包,在生產者和消費者之間共用):

package com.xrq.dubbo.demo;

public interface DemoService
{
    String sayHello(String name);    
}

在服務生產者處實現介面(對服務消費者隱藏介面實現細節):

package com.xrq.dubbo.demo.provider;

import com.xrq.dubbo.demo.DemoService;

public class DemoServiceImpl implements DemoService
{
    public String sayHello(String name)
    {
        return "Hello " + name;
    }
}

寫一個provider.xml,在服務生產者使用Spring暴露服務:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
    xsi:schemaLocation="http://www.springframework.org/schema/beans        
    http://www.springframework.org/schema/beans/spring-beans.xsd
    http://code.alibabatech.com/schema/dubbo
    http://code.alibabatech.com/schema/dubbo/dubbo.xsd"
> <!-- 提供方應用信息,用於計算依賴關係 --> <dubbo:application name="hello-world-app" /> <!-- 使用multicast廣播註冊中心暴露服務地址 --> <dubbo:registry address="multicast://224.5.6.7:1234" /> <!-- 用dubbo協議在20880埠暴露服務 --> <dubbo:protocol name="dubbo" port="20880" /> <!-- 聲明需要暴露的服務介面 --> <dubbo:service interface="com.xrq.dubbo.demo.DemoService" ref="demoService" /> <!-- 和本地bean一樣實現服務 --> <bean id="demoService" class="com.xrq.dubbo.demo.provider.DemoServiceImpl" /> </beans>

在服務消費者處寫一個consumer.xml引用遠程服務:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"
    xsi:schemaLocation="http://www.springframework.org/schema/beans        
    http://www.springframework.org/schema/beans/spring-beans.xsd
    http://code.alibabatech.com/schema/dubbo
    http://code.alibabatech.com/schema/dubbo/dubbo.xsd"
> <!-- 消費方應用名,用於計算依賴關係,不是匹配條件,不要與提供方一樣 --> <dubbo:application name="consumer-of-helloworld-app" /> <!-- 使用multicast廣播註冊中心暴露發現服務地址 --> <dubbo:registry address="multicast://224.5.6.7:1234" /> <!-- 生成遠程服務代理,可以和本地bean一樣使用demoService --> <dubbo:reference id="demoService" interface="com.alibaba.dubbo.demo.DemoService" /> </beans>

服務消費者處只要通過Spring拿到demoService,即可像使用本地介面一樣使用DemoService這個介面裡面的方法:

import org.springframework.context.support.ClassPathXmlApplicationContext;
import com.xrq.dubbo.demo.DemoService;
 
public class Consumer 
{
    public static void main(String[] args) throws Exception    
    {
        ClassPathXmlApplicationContext context = 
new ClassPathXmlApplicationContext(new String[] {"http://aaa.bbb.ccc:dddd/eee/fff/consumer.xml"}); context.start(); DemoService demoService = (DemoService)context.getBean("demoService"); // 獲取遠程服務代理 String hello = demoService.sayHello("world"); // 執行遠程方法 System.out.println(hello); // 顯示調用結果 } }

看到整個過程中:

1、沒有任何Dubbo的代碼,使用Dubbo的時候全部都是Spring配置,這就是前面提到的Dubbo對應用沒有任何API侵入

2、不需要考慮底層線程模型、序列化、反序列化、url解析等問題,這些都是Dubbo底層做好的

 

Dubbo常用標簽

首先說一個優先順序的問題,在dubbo中比如timeout、retries、loadbalance等參數可以在多個標簽內同時配置,它們之間的優先順序,dubbo手冊上是這麼說的:

OK,下麵羅列一些Dubbo常用的,也就是說每個項目的Dubbo的xml文件中基本都會出現的標簽,並以表格形式列舉標簽中常見的可用屬性。

1、<dubbo:service /> 用於服務生產者暴露服務配置

屬    性 類    型 是否必填 預設值 描    述
interface class 必填 服務介面全路徑
ref object 必填 服務對象實現引用
version string 可選 0.0.0 服務版本,建議使用兩位數字版本如1.0,通常在介面不相容時版本號才需要升級
timeout int 可選 1000 遠程服務調用超時時間(毫秒)
retries int 可選 2 遠程服務調用重試次數,不包括第一次調用,不需要重試請設為0
connections int 可選 100 每個生產者的最大連接數,短連接協議如rmi,表示限制連接數;長連接協議如dubbo表示建立的長連接個數
loadbalance string 可選 random 負載均衡策略,可選值為:random(隨機)、roundrobin(輪詢)、leastactive(最少活躍調用)
async boolean 可選 false 是否預設非同步執行,不可靠的非同步,只是忽略返回值,不阻塞執行線程
register boolean 可選 true 該協議的服務是否註冊到註冊中心

2、<dubbo:reference /> 用於服務消費者引用服務配置

屬    性 類    型 是否必填 預設值 描    述
id string 必填 服務引用beanId
interface class 必填 服務介面全路徑
version string 可選 服務版本,與服務生產者的版本一致
timeout long 可選 使用<dubbo:consumer>的timeout  服務方法調用超時時間(毫秒)
retries int 可選 使用<dubbo:consumer>的retries 遠程服務調用重試次數,不包括第一次調用,不需要重試請設為0
connections  int  可選  使用<dubbo:consumer>的connections  每個生產者的最大連接數,短連接協議如rmi,表示限制連接數;長連接協議如dubbo表示建立的長連接個數
loadbalance  string  可選  使用<dubbo:consumer>的loadbalance  負載均衡策略,可選值為:random(隨機)、roundrobin(輪詢)、leastactive(最少活躍調用) 
 async boolean  可選  使用<dubbo:consumer>的async  是否預設非同步執行,不可靠的非同步,只是忽略返回值,不阻塞執行線程 
check boolean  可選 使用<dubbo:consumer>的check  啟動時檢查服務生產者是否存在,true則報錯,false則忽略 
 url string  可選  無  點對點直連服務提供者地址,將繞過註冊中心,比如"dubbo://localhost:20890",這個比較多的使用在測試中 
protocol  string  可選  只調用指定協議的服務生產者,其他協議忽略 

3、<dubbo:protocol /> 用於服務生產者協議配置(如果需要支持多協議,可以聲明多個此標簽,併在<dubbo:service />通過protocol屬性指定使用的協議)

屬    性 類    型 是否必填 預設值 描    述
id string 可選 dubbo 協議beanId,<dubbo service />中的protocol引用此ID,如果不填預設和name屬性值一樣
name sring 必填 dubbo 協議名稱
port int 可選

dubbo->20800,rmi->1099,http->80,hessian->80

如果配置為-1或未配置,則會分配一個沒有被占用的埠

服務埠
host string 可選 自動查找本機ip

為空則自動查找本機ip,建議不配置讓Dubbo自動獲取本機ip

threadpool string 可選 fixed 線程池類型,可選fixed/cached
threads int 可選 100 服務線程池大小(固定大小)
serialization string 可選 dubbo->hession2,rmi->java,http->json 協議序列化方式,當協議支持多種序列化方式時使用
register boolean 可選 true 該協議的服務是否註冊到註冊中心

4、<dubbo:registry /> 用於註冊中心配置(如果有多個不同的註冊中心可以聲明多個標簽並且<dubbo:service />或<dubbo:reference />中使用registry屬性指定)

屬    性 類    型 是否必填 預設值 描    述
id string 可選 註冊中心引用beanId,可在<dubbo:service />或<dubbo:reference />中引用此ID
address string 必填

註冊中心服務地址,如果地址沒有埠預設為9090,同一個集群內的多個地址用逗號分隔,如:ip:port,ip:port,不同的

集群註冊中心請配置多個<dubbo:registry />標簽

 protocol string   可選  dubbo  註冊中心地址協議,支持dubbo、http、local三種協議,分別表示dubbo地址、http地址和本地註冊中心 
port int 可選 9090 註冊中心預設埠,當address沒有帶埠時使用此埠作為預設值 
username string 可選 登陸註冊中心用戶名,如果註冊中心不需要驗證可不填
password string 可選 登陸註冊中心密碼,如果註冊中心不需要驗證可不填 
transport string 可選 netty 網路傳輸方式,可選mina、netty
timeout int 可選 5000 註冊中心請求超時時間(毫秒)
file string 可選 使用文件緩存註冊中心地址列表以及服務提供者列表,應用重啟時將基於此文件恢復,註意兩個註冊中心不能使用同一文件存儲
check boolean 可選 true 註冊中心不存在時,是否報錯
register boolean 可選 true 是否向此註冊中心註冊服務,如果設為false,將只訂閱,不註冊
subscribe boolean 可選 true 是否向此註冊中心訂閱服務,如果設為false,將只註冊,不訂閱

5、<dubbo:method />用於方法級配置(該標簽為<dubbo:service/>或<dubbo:reference/>的子標簽,用於控制到方法級)

屬    性 類    型 是否必填 預設值 描    述
method string 必填 方法名
timeout int 可選 預設為<dubbo:reference/>的timeout 方法調用超時時間(毫秒)
retires int 可選 預設為<dubbo:reference/>的retries 遠程服務調用重試次數,不包括第一次調用,不需要重試請設為0
loadbalance string 可選 預設為<dubbo:reference/>的loadbalance 負載均衡策略,可選值為:random(隨機)、roundrobin(輪詢)、leastactive(最少活躍調用) 
async boolean 可選 預設為<dubbo:reference/>的async 是否非同步執行,不可靠非同步,只是忽略返回值,不阻塞執行線程
actives int 可選 0 每服務消費者最大併發調用限制
 executes int  可選 0 每服務每方法最大使用線程數限制,此屬性只在<dubbo:method/>作為<dubbo:service/>子標簽時有效

另外,還有<dubbo:provider/>和<dubbo:consumer/>分別表示服務提供者(生產者)和服務消費者的預設值配置,就不列舉了。

 

Dubbo協議dubbo://

前面有說到一個Dubbo協議,下麵來看一下Dubbo協議。

Dubbo協議Dubbo的預設協議,使用基於mina1.1.7+hessian3.2.1的tbremoting交互。

  • 連接個數:單連接
  • 連接方式:長連接
  • 傳輸協議:TCP
  • 傳輸方式:NIO非同步傳輸
  • 序列化:Hessian二進位序列化
  • 適用範圍:傳入傳出參數數據包較小(建議小於100K),消費者比提供者個數多,單一消費者無法壓滿提供者,儘量不要使用dubbo協議傳輸大文件或超大字元串
  • 使用場景:常規遠程服務方法調用

從上面的適用範圍總結,dubbo適合小數據量大併發的服務調用,以及消費者機器遠大於生產者機器數的情況,不適合傳輸大數據量的服務比如文件、視頻等,除非請求量很低

另外,Dubbo手冊還給開發者列出了Dubbo協議使用的約束:

  1. 參數及返回值需要實現Serializable介面
  2. 參數及返回值自定義實現List、Map、Number、Date、Calendar等介面,只能用JDK自帶的實現,因為hessian會做特殊處理,自定義實現類中的屬性值都會丟失

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1、什麼是類? 面向對象的語言,最基本的就是類。在C#中,類是這樣來定義的:類代表一組具有公共屬性和行為的對象。 舉個例子,現實生活中,人就是一個“類”,但這隻是一個統稱,指所有的人。我們要找個人一起去玩,此時就需要找到一個具體的人。比如我和小紅,我們兩個就是“人”這個類的兩個實例。 2、C#中如何 ...
  • 總結C#獲取當前路徑的7種方法 C#獲取當前路徑的方法如下: 1. System.Diagnostics.Process.GetCurrentProcess().MainModule.FileName -獲取模塊的完整路徑。 2. System.Environment.CurrentDirector ...
  • Html.ActionLink 在 LinkExtensions 類中,ActionLink方法參數說明: 簡單來說捏 就是這樣滴 參數 類型 說明 linkText string 生成的鏈接所顯示的文字 actionName string 對應控制器的方法 controllerName strin ...
  • 前言:上學期GIS空間資料庫課程設計時,老師讓實現Shp-柵格圖形文件的讀取與顯示,外加shp轉WKB格式存入oracle,不使用第三方類庫,花了一天時間在網上找了一些資料,實現了一個簡單的柵格圖形文件的顯示。 有時候我們知道了一個文件的存儲格式,便可以寫個程式輕輕鬆松讀取出來想要的數據,讀取的時候 ...
  • 上次在UWP中的消息提示框(二)中談到彈出框在虛擬導航欄的手機上被遮擋問題,今天接就著扯。 上次給用戶控制項指定的寬高都是Window.Current.Bounds的寬高,而這個獲取到的是包含應用程式視窗的高度和寬度(以有效(視圖)像素為單位)的 Rect 值,在手機上是狀態欄和虛擬導航欄的高度也算進 ...
  • 分類:Unity、C#、VS2015 創建日期:2016-03-26 本章要點: 1、掌握Unity 5.3.4編輯器視圖和菜單項及其含義,這是入門的最基礎部分,必須掌握。 2、瞭解最基本的操作,先學會模仿著向場景中添加一些簡單的對象。 本章目錄安排如下: 2.1 初識Unity 5.3.4編輯器 ... ...
  • 具體方法如下: 請求行相關方法: getMethod()獲得請求行的方法,如:get,post等 getRequestURI()獲得請求的統一資源標識符(相對的,不包含QueryString)(URL是一種具體的URI,它不僅唯一標識資源,而且還提供了定位該資源的信息。URI是一種語義上的抽象概念, ...
  • 最近看了nginx以及tomcat的集群,做一下簡單總結吧 nginx 是一個http伺服器,是有俄羅斯人發明的,目前主流的伺服器,作為負載均衡伺服器,性能非常好,最高支持5萬個併發連接數,在淘寶被廣泛使用 單個tomcat最大支持的用戶併發量預設是150,在測試過程中250左右開始會有性能的問題 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...