①dubbo協議
Dubbo缺省協議採用單一長鏈接和NIO異步通信,適合於小數據量大併發的服務調用,以及服務消費者機器數遠大於服務提供者機器數的狀況。
特色 :java
爲何要消費者比提供者個數多: 因dubbo協議採用單一長鏈接, 假設網絡爲千兆網卡(1024Mbit=128MByte), 根據測試經驗數據每條鏈接最多隻能壓滿7MByte(不一樣的環境可能不同,供參考), 理論上1個服務提供者須要20個服務消費者才能壓滿網卡。json
爲何不能傳大包: 因dubbo協議採用單一長鏈接, 若是每次請求的數據包大小爲500KByte,假設網絡爲千兆網卡(1024Mbit=128MByte),每條鏈接最大7MByte(不一樣的環境可能不同,供參考), 單個服務提供者的TPS(每秒處理事務數)最大爲:128MByte / 500KByte = 262。 單個消費者調用單個服務提供者的TPS(每秒處理事務數)最大爲:7MByte / 500KByte = 14。 若是能接受,能夠考慮使用,不然網絡將成爲瓶頸。瀏覽器
爲何採用異步單一長鏈接: 由於服務的現狀大都是服務提供者少,一般只有幾臺機器, 而服務的消費者多,可能整個網站都在訪問該服務, 好比Morgan的提供者只有6臺提供者,卻有上百臺消費者,天天有1.5億次調用, 若是採用常規的hessian服務,服務提供者很容易就被壓跨, 經過單一鏈接,保證單一消費者不會壓死提供者, 長鏈接,減小鏈接握手驗證等, 並使用異步IO,複用線程池,防止C10K問題。服務器
②RMI協議
RMI協議採用JDK的java.rmi.*來實現,採用的是 阻塞式短鏈接和標準化的JDK序列化方式。網絡
特色 :併發
③Hessian協議
Hessian協議用於集成Hessian的服務,Hessian底層採用Http通信,採用Servlet暴露服務,Dubbo缺省內嵌jetty做爲服務器。
特色 :框架
④Http協議
採用Spring的HttpInvoker實現。
特色frontend
⑤WebService協議異步
基於CXF的frontend-simple和transports-http實現。
** 特色**性能
⑥thrif協議
Thrift是Facebook捐給Apache的一個RPC框架,當前 dubbo 支持的 thrift 協議是對 thrift 原生協議的擴展,在原生協議的基礎上添加了一些額外的頭信息,好比service name,magic number等。
dubbo實際基於不一樣的通訊協議,支持hessian、java二進制序列化、json、SOAP文本序列化多種序列化協議。可是hessian是其默認的序列化協議。
①Hessian序列化。
hessian是一種跨語言的高效二進制的序列化方式,但這裏實際不是原生的hessian2序列化,而是阿里修改過的hessian lite,它是dubbo RPC默認啓用的序列化方式。
②Java二進制序列化。
主要是採用JDK自帶的java序列化實現,性能很不理想。
③Json序列化
目前有兩種實現,一種是採用的阿里的fastjson庫,另外一種是採用dubbo中自已實現的簡單json庫,通常狀況下,json這種文本序列化性能不如二進制序列化。
④SOAP文本序列化。 簡單對象訪問協議是交換數據的一種協議規範,是一種輕量的、簡單的、基於XML的協議,它被設計成在WEB上交換結構化的和固化的信息。