Dubbo是什么?
Dubbo能做什么?
Dubbo內置了哪幾種服務容器?
Dubbo 核心的配置有哪些?
Dubbo有哪幾種集群容錯方案,默認是哪種?
Dubbo有哪幾種負載均衡策略,默認是哪種?
Dubbo默認使用的是什么通信框架,還有別的選擇嗎?
你覺得用Dubbo好還是SpringCloud好?
1.Dubbo是什么?
Dubbo是阿里巴巴開源的基於 Java 的高性能 RPC 分布式服務框架,現已成為 Apache 基金會孵化項目。致力於提供高性能和透明化的RPC遠程服務調用方案,以及SOA服務治理方案。
簡單的說,dubbo就是個服務框架,如果沒有分布式的需求,其實是不需要用的,只有在分布式的時候,才有dubbo這樣的分布式服務框架的需求,並且本質上是個服務調用的東東,說白了就是個遠程服務調用的分布式框架(告別Web Service模式中的WSdl,以服務者與消費者的方式在dubbo上注冊)
其核心部分包含:
遠程通訊: 提供對多種基於長連接的NIO框架抽象封裝,包括多種線程模型,序列化,以及“請求-響應”模式的信息交換方式。
集群容錯: 提供基於接口方法的透明遠程過程調用,包括多協議支持,以及軟負載均衡,失敗容錯,地址路由,動態配置等集群支持。
自動發現: 基於注冊中心目錄服務,使服務消費方能動態的查找服務提供方,使地址透明,使服務提供方可以平滑增加或減少機器。
2. Dubbo能做什么?
透明化的遠程方法調用,就像調用本地方法一樣調用遠程方法,只需簡單配置,沒有任何API侵入。
軟負載均衡及容錯機制,可在內網替代F5等硬件負載均衡器,降低成本,減少單點。
服務自動注冊與發現,不再需要寫死服務提供方地址,注冊中心基於接口名查詢服務提供者的IP地址,並且能夠平滑添加或刪除服務提供者。
Dubbo采用全Spring配置方式,透明化接入應用,對應用沒有任何API侵入,只需用Spring加載Dubbo的配置即可,Dubbo基於Spring的Schema擴展進行加載。
3.Dubbo內置了哪幾種服務容器?
Spring Container
Jetty Container
Log4j Container
4.Dubbo 核心的配置有哪些?
配置關系:
5.Dubbo有哪幾種集群容錯方案,默認是哪種?
6.Dubbo有哪幾種負載均衡策略,默認是哪種?
7.Dubbo默認使用的是什么通信框架,還有別的選擇嗎?
Dubbo 默認使用 Netty 框架,也是推薦的選擇,另外內容還集成有Mina、Grizzly。
8.你覺得用Dubbo好還是SpringCloud好?
沒有好壞,只有適合不適合。
dubbo的優勢
單一應用架構,當網站流量很小時,只需一個應用,將所有功能都部署在一起,以減少部署節點和成本。此時,用於簡化增刪改查工作量的 數據訪問框架(ORM)是關鍵。
垂直應用架構,當訪問量逐漸增大,單一應用增加機器帶來的加速度越來越小,將應用拆成互不相干的幾個應用,以提升效率。此時,用於加速前端頁面開發的 Web框架(MVC)是關鍵。
分布式服務架構,當垂直應用越來越多,應用之間交互不可避免,將核心業務抽取出來,作為獨立的服務,逐漸形成穩定的服務中心,使前端應用能更快速的響應多變的市場需求。此時,用於提高業務復用及整合的 分布式服務框架(RPC)是關鍵。
流動計算架構當服務越來越多,容量的評估,小服務資源的浪費等問題逐漸顯現,此時需增加一個調度中心基於訪問壓力實時管理集群容量,提高集群利用率。此時,用於提高機器利用率的 資源調度和治理中心(SOA)是關鍵。
SpringCloud優勢
約定優於配置
開箱即用、快速啟動
適用於各種環境
輕量級的組件
組件支持豐富,功能齊全
兩者相比較
1、dubbo由於是二進制的傳輸,占用帶寬會更少
2、springCloud是http協議傳輸,帶寬會比較多,同時使用http協議一般會使用JSON報文,消耗會更大
3、dubbo的開發難度較大,原因是dubbo的jar包依賴問題很多大型工程無法解決
4、springcloud的接口協議約定比較自由且松散,需要有強有力的行政措施來限制接口無序升級
5、dubbo的注冊中心可以選擇zk,redis等多種,springcloud的注冊中心只能用eureka或者自研
根據具體的團隊水平,業務情況等特點,dubbo和SpringCloud各自可以發揮各自不同的優勢,沒有最好的框架,只有最合適的。(這道題比較靈活,要是提前知道對方公司采用的是哪個,可以使勁吹哪個~)
最近三期