Java 序列化框架性能對(duì)比(kryo估灿、hessian、java脾歧、protostuff)

簡(jiǎn)介:

優(yōu)點(diǎn) 缺點(diǎn)
Kryo 速度快甲捏,序列化后體積小 跨語(yǔ)言支持較復(fù)雜
Hessian 默認(rèn)支持跨語(yǔ)言 較慢
Protostuff 速度快演熟,基于protobuf 需靜態(tài)編譯
Protostuff-Runtime 無(wú)需靜態(tài)編譯鞭执,但序列化前需預(yù)先傳入schema 不支持無(wú)默認(rèn)構(gòu)造函數(shù)的類(lèi)司顿,反序列化時(shí)需用戶(hù)自己初始化序列化后的對(duì)象,其只負(fù)責(zé)將該對(duì)象進(jìn)行賦值
Java 使用方便兄纺,可序列化所有類(lèi) 速度慢大溜,占空間

測(cè)試環(huán)境:

硬件信息:

     16 Intel(R) Xeon(R) CPU E5620 @2.40GHz

     Red Hat Enterprise Linux Server release 5.4 (Tikanga)

     java:  "1.6.0\_27" Java HotSpot(TM) 64-Bit Server VM (build 20.2-b06, mixed mode)

     JVM options: java -Xmx256m –server

測(cè)試數(shù)據(jù):(見(jiàn)附件)

     ArrayList.class

     MediaContent.class

     Media.class

     Image.class

測(cè)試方法:(參考自 https://github.com/eishay/jvm-serializers

1、 在正式測(cè)試之前估脆,將測(cè)試用例運(yùn)行10次對(duì)JVM進(jìn)行預(yù)熱钦奋。

2、 對(duì)測(cè)試用例的每個(gè)方法疙赠,運(yùn)行2000次付材,取平均值。

3圃阳、 每次測(cè)試用例運(yùn)行500次厌衔,取最優(yōu)結(jié)果

測(cè)試基準(zhǔn):

     ser:           創(chuàng)建一個(gè)對(duì)象,并將其序列化成byte數(shù)組的時(shí)間

     deser:       將byte數(shù)組反序列化成對(duì)象的時(shí)間

     total:        創(chuàng)建一個(gè)對(duì)象捍岳,將其序列化成byte數(shù)組再反序列化為對(duì)象的總時(shí)間

     size:          序列化后的數(shù)組大小

     size+dfl:   序列化后用level6級(jí)別的zlib進(jìn)行壓縮后的大小

測(cè)試工具:

序列化工具 序列化方式
kryo 使用kryo默認(rèn)的序列化方式fieldSerializer富寿,對(duì)需要序列化的對(duì)象采取默認(rèn)的操作。開(kāi)啟reference锣夹,關(guān)閉register
protostuff 使用靜態(tài)編譯生成的Schema進(jìn)行序列化
protostuff-runtime 使用protostuff-runtime框架生成Schema進(jìn)行序列化

測(cè)試結(jié)果:

     時(shí)間:

     大幸承臁:

總結(jié):

     Kryo在類(lèi)注冊(cè)且reference關(guān)閉的情況下,序列化速度和大小明顯 優(yōu)于hessian和java银萍,接近于protostuff变勇。開(kāi)啟reference后將序列化速度將明顯變慢,但仍舊優(yōu)于hessian贴唇。

相關(guān)知識(shí):

     類(lèi)注冊(cè):將需要序列化的類(lèi)注冊(cè)到kryo中贰锁,可以提高序列化與反序列化的速度。

     Reference:開(kāi)啟這個(gè)選項(xiàng)后滤蝠,相同的對(duì)象將被序列化為同一個(gè)byte[]豌熄,默認(rèn)關(guān)閉,如果要支持循環(huán)引用物咳,則必須開(kāi)啟

穩(wěn)定性測(cè)試:

測(cè)試用例(見(jiàn)附件)

     循環(huán)引用:Cyclic.java
序列化方式 無(wú)默認(rèn)構(gòu)造函數(shù) 循環(huán)引用 對(duì)象為null 是否需要預(yù)先知道對(duì)象所屬的類(lèi) 大對(duì)象(4M)
Kryo 支持 需將reference選項(xiàng)打開(kāi) 支持 不需要锣险,關(guān)閉register 支持
Java 支持 支持 支持 不需要 支持
Protostuff 支持 支持 支持 不需要 支持
Protostuff**** -runtime 不支持 支持 支持 需要 支持
Hessian 支持 支持 支持 不需要 支持

via http://x-rip.iteye.com/blog/1555293

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市览闰,隨后出現(xiàn)的幾起案子芯肤,更是在濱河造成了極大的恐慌,老刑警劉巖压鉴,帶你破解...
    沈念sama閱讀 206,482評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件崖咨,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡油吭,警方通過(guò)查閱死者的電腦和手機(jī)击蹲,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,377評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門(mén)署拟,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人歌豺,你說(shuō)我怎么就攤上這事推穷。” “怎么了类咧?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,762評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵姿骏,是天一觀的道長(zhǎng)糠聪。 經(jīng)常有香客問(wèn)我,道長(zhǎng),這世上最難降的妖魔是什么抡诞? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,273評(píng)論 1 279
  • 正文 為了忘掉前任捅伤,我火速辦了婚禮萧落,結(jié)果婚禮上端逼,老公的妹妹穿的比我還像新娘。我一直安慰自己述寡,他們只是感情好柿隙,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,289評(píng)論 5 373
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著鲫凶,像睡著了一般禀崖。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上螟炫,一...
    開(kāi)封第一講書(shū)人閱讀 49,046評(píng)論 1 285
  • 那天波附,我揣著相機(jī)與錄音,去河邊找鬼昼钻。 笑死掸屡,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的然评。 我是一名探鬼主播仅财,決...
    沈念sama閱讀 38,351評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼碗淌!你這毒婦竟也來(lái)了盏求?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 36,988評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤亿眠,失蹤者是張志新(化名)和其女友劉穎碎罚,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體纳像,經(jīng)...
    沈念sama閱讀 43,476評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡荆烈,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,948評(píng)論 2 324
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了竟趾。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片憔购。...
    茶點(diǎn)故事閱讀 38,064評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡宫峦,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出倦始,到底是詐尸還是另有隱情,我是刑警寧澤山卦,帶...
    沈念sama閱讀 33,712評(píng)論 4 323
  • 正文 年R本政府宣布鞋邑,位于F島的核電站,受9級(jí)特大地震影響账蓉,放射性物質(zhì)發(fā)生泄漏枚碗。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,261評(píng)論 3 307
  • 文/蒙蒙 一铸本、第九天 我趴在偏房一處隱蔽的房頂上張望肮雨。 院中可真熱鬧,春花似錦箱玷、人聲如沸怨规。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,264評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)波丰。三九已至,卻和暖如春舶得,著一層夾襖步出監(jiān)牢的瞬間掰烟,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,486評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工沐批, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留纫骑,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,511評(píng)論 2 354
  • 正文 我出身青樓九孩,卻偏偏與公主長(zhǎng)得像先馆,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子躺彬,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,802評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開(kāi)發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見(jiàn)模式的工具(例如配置管理磨隘,服務(wù)發(fā)現(xiàn),斷路器顾患,智...
    卡卡羅2017閱讀 134,599評(píng)論 18 139
  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,510評(píng)論 25 707
  • 1.測(cè)試與軟件模型 軟件開(kāi)發(fā)生命周期模型指的是軟件開(kāi)發(fā)全過(guò)程番捂、活動(dòng)和任務(wù)的結(jié)構(gòu)性框架。軟件項(xiàng)目的開(kāi)發(fā)包括:需求江解、設(shè)...
    Mr希靈閱讀 21,938評(píng)論 7 278
  • 今天的咨詢(xún)里设预,難過(guò)的情緒很多。好像有一些東西想要沖出來(lái)犁河,但是又不是那么地容易出來(lái)鳖枕。 和咨詢(xún)師的交流魄梯,我給她的建議,...
    BelovedNutan閱讀 335評(píng)論 0 0
  • 喜歡一個(gè)人對(duì)于自己來(lái)說(shuō)辣苏,喜歡了就是喜歡了,可是要讓自己喜歡的人也喜歡自己是一件很難的事哄褒,我現(xiàn)在有點(diǎn)稀蟋,彷徨,我一直在...
    子培君的日記閱讀 1,043評(píng)論 0 0