1. 程式人生 > >RMI、Hessian、Burlap、Httpinvoker、WebService的比較

RMI、Hessian、Burlap、Httpinvoker、WebService的比較

一、綜述
本文比較了RMI、Hessian、Burlap、Httpinvoker、WebService5這種通訊協議的在不同的資料結構和不同資料量時的傳輸效能。
RMI是java語言本身提供的遠端通訊協議,穩定高效,是EJB的基礎。但它只能用於JAVA程式之間的通訊。
Hessian和Burlap是caucho公司提供的開源協議,基於HTTP傳輸,服務端不用開防火牆埠。協議的規範公開,可以用於任意語言。
Httpinvoker是SpringFramework提供的遠端通訊協議,只能用於JAVA程式間的通訊,且服務端和客戶端必須使用SpringFramework。
Web service是連線異構系統或異構語言的首選協議,它使用SOAP形式通訊,可以用於任何語言,目前的許多開發工具對其的支援也很好。

測試結果顯示,幾種協議的通訊效率依次為:
RMI > Httpinvoker >= Hessian >> Burlap>> web service


RMI不愧是JAVA的首選遠端呼叫協議,非常高效穩定,特別是在大資料量的情況下,與其他通訊協議的差距尤為明顯。
HttpInvoker使用java的序列化技術傳輸物件,與RMI在本質上是一致的。從效率上看,兩者也相差無幾,HttpInvoker與RMI的傳輸時間基本持平。
Hessian在傳輸少量物件時,比RMI還要快速高效,但傳輸資料結構複雜的物件或大量資料物件時,較RMI要慢20%左右。
Burlap僅在傳輸1條資料時速度尚可,通常情況下,它的毫時是RMI的3倍。
Web Service的效率低下是眾所周知的,平均來看,Web Service的通訊毫時是RMI的10倍。

二、結果分析
1、直接呼叫

直接呼叫的所有毫時都接近0,這說明程式處理幾乎沒有花費時間,記錄的全部時間都是遠端呼叫耗費的。
2、RMI呼叫
與設想的一樣,RMI理所當然是最快的,在幾乎所有的情況下,它的毫時都是最少的。特別是在資料結構複雜,資料量大的情況下,與其他協議的差距尤為明顯。
為 了充分發揮RMI的效能,另外做了測試類,不使用Spring,用原始的RMI形式(繼承UnicastRemoteObject物件)提供服務並遠端呼叫,與Spring對POJO包裝成的RMI進行效率比較。結果顯示:兩者基本持平,Spring提供的服務還稍快些。
初步認為,這是因為Spring的代理和快取機制比較強大,節省了物件重新獲取的時間。
3、Hessian呼叫
caucho 公司的resin伺服器號稱是最快的伺服器,在java領域有一定的知名度。Hessian做為resin的組成部分,其設計也非常精簡高效,實際執行情況也證明了這一點。平均來看,Hessian較RMI要慢20%左右,但這只是在資料量特別大,資料結構很複雜的情況下才能體現出來,中等或少量資料時,Hessian並不比RMI慢。
Hessian的好處是精簡高效,可以跨語言使用,而且協議規範公開,我們可以針對任意語言開發對其協議的實現。目前已有實現的語言有:java, c++, .net, python, ruby。還沒有delphi的實現。
另 外,Hessian與WEB伺服器結合非常好,藉助WEB伺服器的成熟功能,在處理大量使用者併發訪問時會有很大優勢,在資源分配,執行緒排隊,異常處理等方 面都可以由成熟的WEB伺服器保證。而RMI本身並不提供多執行緒的伺服器。而且,RMI需要開防火牆埠,Hessian不用。
4、Burlap呼叫
Burlap與Hessian都是caucho公司的開源產品,只不過Hessian採用二進位制的方式,而Burlap採用xml的格式。
測試結果顯示,Burlap在資料結構不復雜,資料量中等的情況下,效率還是可以接受的,但如果資料量大,效率會急劇下降。平均計算,Burlap的呼叫毫時是RMI的3倍。
我認為,其效率低有兩方面的原因,一個是XML資料描述內容太多,同樣的資料結構,其傳輸量要大很多;另一方面,眾所周知,對xml的解析是比較費資源的,特別對於大資料量情況下更是如此。
5、HttpInvoker呼叫
HttpInvoker是SpringFramework提供的JAVA遠端呼叫方法,使用java的序列化機制處理物件的傳輸。從測試結果看,其效率還是可以的,與RMI基本持平。
不過,它只能用於JAVA語言之間的通訊,而且,要求客戶端和服務端都使用SPRING框架。
另外,HttpInvoker 並沒有經過實踐的檢驗,目前還沒有找到應用該協議的專案。
6、web service呼叫
本次測試選用了apache的AXIS元件作為WEB SERVICE的實現,AXIS在WEBSERVICE領域相對成熟老牌。
為了僅測試資料傳輸和編碼、解碼的時間,客戶端和服務端都使用了快取,物件只需例項化一次。但是,測試結果顯示,webservice的效率還是要比其他通訊協議慢10倍。
如果考慮到多個引用指向同一物件的傳輸情況,web service要落後更多。因為RMI,Hessian等協議都可以傳遞引用,而web service有多少個引用,就要複製多少份物件實體。
Web service傳輸的冗餘資訊過多是其速度慢的原因之一,監控發現,同樣的訪問請求,描述相同的資料,webservice返回的資料量是hessian協議的6.5倍。另外,WEB SERVICE的處理也很毫時,目前的xml解析器效率普遍不高,處理xml <-> bean很毫資源。從測試結果看,異地呼叫比本地呼叫要快,也從側面說明了其毫時主要用在編碼和解碼xml檔案上。這比冗餘資訊更為嚴重,冗餘資訊佔用的 只是網路頻寬,而每次呼叫的資源耗費直接影響到伺服器的負載能力。(MS的工程師曾說過,用WEB SERVICE不能負載100個以上的併發使用者。)
測試過程中還發現,web service編碼不甚方便,對非基本型別需要逐個註冊序列化和反序列化類,很麻煩,生成stub更累,不如spring + RMI/hessian處理那麼流暢簡潔。而且,web service不支援集合型別,只能用陣列,不方便。

三、Hession機制

相關推薦

RMIHessianBurlapHttpinvokerWebService比較

一、綜述本文比較了RMI、Hessian、Burlap、Httpinvoker、WebService5這種通訊協議的在不同的資料結構和不同資料量時的傳輸效能。 RMI是java語言本身提供的遠端通訊協議,穩定高效,是EJB的基礎。但它只能用於JAVA程式之間的通訊。 Hes

WebService之RPC的(Axis2CXFJerseyHessian)4中實現方式

一、什麼是WebService Web service是一個平臺獨立的,低耦合的,自包含的、基於可程式設計的web的應用程式,可使用開放的XML(標準通用標記語言下的一個子集)標準來描述、釋出、發現、協調和配置這些應用程式,用於開發分散式的互操作的應用程式。 Web

實現 序列化引擎(支援 JDK預設HessianJsonProtostuffXmlAvroProtocolBufferThrift等序列化方式)

本文將實現一個包含JDK預設、Hessian、Json、Protostuff、Xml、Avro、ProtocolBuffer、Thrift等序列化方式的序列化引擎。使用者可以提供使用 SerializerEngine 方便快捷地切換序列化方法實現。 文章目錄

KryomsgpackprotobufHessianAvroThrift等序列化框架比較

最近一直在想如果讓我自己來做一個服務化框架出來,該實現些什麼功能,具體該怎麼去做這樣的問題,資料序列化是一個重要的模組,故此有意對常見的一些開源序列化框架做一個比較! 我個人對Hessian、Java、protobuf、Thrift這幾種序列化方式比較熟悉,但是對Kryo、

梯度Hessian矩陣平面方程的法線以及函式導數的含義

想必單獨論及“ 梯度、Hessian矩陣、平面方程的法線以及函式導數”等四個基本概念的時候,絕大部分人都能夠很容易地談個一二三,基本沒有問題。 其實在應用的時候,這幾個概念經常被混淆,本文試圖把這幾個概念之間的關係整理一下,以便應用之時得心應手。 這四個概念中,Hessia

序列化框架效能對比(kryohessianjavaprotostuff)

序列化框架效能對比(kryo、hessian、java、protostuff) 簡介: 優點 缺點 Kryo 速度快,序列化後體積小 跨語言支援較複雜 Hessian 預設支援跨語言 較慢 Protostuff

表單提交 防註入XSS 1入庫時轉義後臺 2出庫轉義前臺

his 驗證 替換字符 插入 如果 不同的 js代碼 urn ida 第一種 入庫過濾js自動填充時過濾js代碼class GoodsModel extends Model{ // 填充 protected $_auto = [ // 自己補充填充

oracle 12c 多租戶 pdb 恢復(單個pdb數據文件非系統pdb表空間整個pdb數據庫)

數據文件 ota ora-01110 創建 正常 方式 cti users rman 環境:數據庫版本 Oracle Database 12c Enterprise Edition Release 12.2.0.1.0 - 64bit Production實驗準備:1.--

Ztree _ 橫向顯示子節點點擊文字勾選去除指定元素input的勾選狀態

.cn hid ttr 很好 clas pre ges tree 效果 前些天項目需要樹結構表現數據,需求ztree就能滿足所以直接使用ztree只是踩了些小坑。。。 1.ztree子節點橫向顯示(下圖): 效果說明:第三級子節點按需求橫向顯示其他豎向顯示,每行最多顯示5

進擊的Python【第九章】:paramiko模塊線程與進程各種線程鎖queue隊列生產者消費者模型

password locking form maxsize 廁所 sorted [0 hostname nbsp 一、paramiko模塊 他是什麽東西?   paramiko模塊是用python語言寫的一個模塊,遵循SSH2協議,支持以加密和認證的方式,進行遠程服務器的連

[C++] 動態規劃之矩陣連乘最長公共子序列最大子段和最長單調遞增子序列

每次 種子 () return 避免 amp 可能 text com 一、動態規劃的基本思想   動態規劃算法通常用於求解具有某種最優性質的問題。在這類問題中,可能會有許多可行解。每一個解都對應於一個值,我們希望找到具有最優值的解。   將待求解問題分解成若幹個子問題,先求

Android----獲得當前應用包名當前activity的名字推斷是否是系統桌面service類

owin agen gac arr ddc add gets small cli 1、獲得當前應用包名 public static String getRunningActivityName(Context context) { ActivityManager acti

struts2的返回類型struts的標簽庫struts2中完成國際化

let 頁面 const patch red struts2標簽 property 單選 bmi struts2的返回類型:在jsp-servlet中, 返回的類型主要有 轉發, 重定向; 轉發主要是RequestDispatcher的forward方法來進行操作的req.

bos 第3天(easyui彈窗邊界問題取派員的添加修改和批量刪除)

檔案 劃分 bug servle 手機號 rules function project rem BOS項目筆記 第3天 今天內容安排: 1、解決window窗口bug 2、bos項目整體需求分析(基礎設置、取派、中轉、路由、報表) 3、取派員添加功能 4、jQuery

struts.xml文件中action配置OGNL的投影映射OGNL表達式的符號

傳參 路徑 req rop [0 path 中一 prop 後綴 在struts.xml文件中不同的action配置,請求的路徑是不一樣的 1、請求 path = user!query.action; 配置如下; <action name="user" class=

bos 第4 (區域excel批量導入區域通用分頁查詢分區的添加分區多條件分頁查詢分區導出excel)

sea htm 不能 長安 基金會 格式 address ret body BOS項目筆記 第4天 今天內容安排: 1、區域批量導入功能 jQuery OCUpload(一鍵上傳插件)、apache POI、pinyin4j 2、實現區域的分頁查詢 3、對分頁代碼重構

11函數對象函數的嵌套名稱空間與作用域

() update 啟動 nbsp money 有效 產生 strip() return 一、函數對象   函數對象,函數是第一類對象,即函數可以當做數據傳遞   具體特點:     1、可以被引用;   1 def foo(): 2 print(‘from fo

數據結構(嚴蔚敏吳偉民)——讀書筆記-2 線性表及其基本運算順序存儲結構

content pri 線性 時間復雜度 length 將他 ron 個數 p s 第二章 線性表 2.1 線性表及其基本運算 2.2 線性表的順序存儲結構 2.3 線性表的鏈式存儲結構 1、線性表:是n個數據元素的有限序列。

sort-list——鏈表快慢指針找中間歸並排序

val 排序。 rtl != spa 判斷 nbsp node ace Sort a linked list in O(n log n) time using constant space complexity. 鏈表,快慢指針找中點,歸並排序。 註意判斷條件fast-

Java初始化順序(靜態變量靜態初始化塊實例變量實例初始化塊構造方法)

靜態初始化 都對 class block 註釋 執行順序 blog 中一 成員變量 1、執行順序 1.1、一個類中的初始化順序 (靜態變量、靜態初始化塊)=>(變量、初始化塊、構造器)。 1.2、兩個具有繼承關系類的初始化順序 父類的(靜態變量、