Dubbo是阿里巴巴公司開源的一個高性能優(yōu)秀的服務框架,使得應用可通過高性能的 RPC 實現服務的輸出和輸入功能,可以和 Spring框架無縫集成。
Dubbo是一款高性能、輕量級的開源Java RPC框架,它提供了三大核心能力:面向接口的遠程方法調用,智能容錯和負載均衡,以及服務自動注冊和發(fā)現。
主要核心部件編輯
Remoting: 網絡通信框架,實現了 sync-over-async 和
request-response 消息機制.
RPC: 一個遠程過程調用的抽象,支持負載均衡、容災和集群功能
Registry: 服務目錄框架用于服務的注冊和服務事件發(fā)布和訂閱
工作原理編輯
Provider
暴露服務方稱之為“服務提供者”。
Consumer
調用遠程服務方稱之為“服務消費者”。
Registry
服務注冊與發(fā)現的中心目錄服務稱之為“服務注冊中心”。
Monitor
統(tǒng)計服務的調用次數和調用時間的日志服務稱之為“服務監(jiān)控中心”。
(1) 連通性:
注冊中心負責服務地址的注冊與查找,相當于目錄服務,服務提供者和消費者只在啟動時與注冊中心交互,注冊中心不轉發(fā)請求,壓力較小
監(jiān)控中心負責統(tǒng)計各服務調用次數,調用時間等,統(tǒng)計先在內存匯總后每分鐘一次發(fā)送到監(jiān)控中心服務器,并以報表展示
服務提供者向注冊中心注冊其提供的服務,并匯報調用時間到監(jiān)控中心,此時間不包含網絡開銷
服務消費者向注冊中心獲取服務提供者地址列表,并根據負載算法直接調用提供者,同時匯報調用時間到監(jiān)控中心,此時間包含網絡開銷
注冊中心,服務提供者,服務消費者三者之間均為長連接,監(jiān)控中心除外
注冊中心通過長連接感知服務提供者的存在,服務提供者宕機,注冊中心將立即推送事件通知消費者
注冊中心和監(jiān)控中心全部宕機,不影響已運行的提供者和消費者,消費者在本地緩存了提供者列表
注冊中心和監(jiān)控中心都是可選的,服務消費者可以直連服務提供者
(2) 健壯性:
監(jiān)控中心宕掉不影響使用,只是丟失部分采樣數據
數據庫宕掉后,注冊中心仍能通過緩存提供服務列表查詢,但不能注冊新服務
注冊中心對等集群,任意一臺宕掉后,將自動切換到另一臺
注冊中心全部宕掉后,服務提供者和服務消費者仍能通過本地緩存通訊
服務提供者無狀態(tài),任意一臺宕掉后,不影響使用
服務提供者全部宕掉后,服務消費者應用將無法使用,并無限次重連等待服務提供者恢復
(3) 伸縮性:
注冊中心為對等集群,可動態(tài)增加機器部署實例,所有客戶端將自動發(fā)現新的注冊中心
服務提供者無狀態(tài),可動態(tài)增加機器部署實例,注冊中心將推送新的服務提供者信息給消費者
特性編輯
面向接口代理的高性能RPC調用
提供高性能的基于代理的遠程調用能力,服務以接口為粒度,為開發(fā)者屏蔽遠程調用底層細節(jié)。
智能負載均衡
內置多種負載均衡策略,智能感知下游節(jié)點健康狀況,顯著減少調用延遲,提高系統(tǒng)吞吐量。
服務自動注冊與發(fā)現
支持多種注冊中心服務,服務實例上下線實時感知。
高度可擴展能力
遵循微內核+插件的設計原則,所有核心能力如Protocol、Transport、Serialization被設計為擴展點,平等對待內置實現和第三方實現。
運行期流量調度
內置條件、腳本等路由策略,通過配置不同的路由規(guī)則,輕松實現灰度發(fā)布,同機房優(yōu)先等功能。
可視化的服務治理與運維
提供豐富服務治理、運維工具:隨時查詢服務元數據、服務健康狀態(tài)及調用統(tǒng)計,實時下發(fā)路由策略、調整配置參數。
鏈接:https://pan.baidu.com/s/1noyE9l2KLyty8MBygDfDkg
如需要獲取提取碼,請先 登錄
本文為張軍原創(chuàng)文章,轉載無需和我聯(lián)系,但請注明來自張軍的軍軍小站,個人博客http://m.eyofj.com
更多文章、技術交流、商務合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯(lián)系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
