青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Fork me on GitHub
隨筆 - 215  文章 - 13  trackbacks - 0
<2017年1月>
25262728293031
1234567
891011121314
15161718192021
22232425262728
2930311234


專注即時通訊及網游服務端編程
------------------------------------
Openresty 官方模塊
Openresty 標準模塊(Opm)
Openresty 三方模塊
------------------------------------
本博收藏大部分文章為轉載,并在文章開頭給出了原文出處,如有再轉,敬請保留相關信息,這是大家對原創作者勞動成果的自覺尊重!!如為您帶來不便,請于本博下留言,謝謝配合。

常用鏈接

留言簿(1)

隨筆分類

隨筆檔案

相冊

Awesome

Blog

Book

GitHub

Link

搜索

  •  

積分與排名

  • 積分 - 219651
  • 排名 - 117

最新評論

閱讀排行榜

http://blog.csdn.net/mycwq/article/details/42122439
改進erlang版本的protobuf
protobuf是google開源的序列化工具,類似xml,json,基于二進制,比XML表示同樣一段內容要短小得多,還可以定義一些可選字段,用于服務端與客戶端通信。google沒有提供對erlang語言的直接支持,所以這里使用到的第三方的protobuffs庫,文章在這個庫的基礎上做一些改進。

在開始閱讀這篇文章前,先了解一下原來erlang版的protobuf使用例子。改進版的protobuf代碼及例子在這里(下載地址)。歡迎下載,有什么問題可以評論反饋。

改進protobuf

改進調用方法

原來調用比較別扭,每個協議都是不同的方法名:
[plain] view plain copy
 在CODE上查看代碼片派生到我的代碼片
  1. encode() ->    
  2.     Person = #person{age=25, name="John"},    
  3.     test_pb:encode_person(Person).    
  4.     
  5. decode() ->    
  6.     Data = encode(),    
  7.     test_pb:decode_person(Data).   
現在改成了統一的方法名:
[plain] view plain copy
 在CODE上查看代碼片派生到我的代碼片
  1. encode() ->    
  2.     Person = #person{age=25, name="John"},    
  3.     test_pb:encode(Person). %% 或者 test_pb:encode(person, Person)  
  4.     
  5. decode() ->    
  6.     Data = encode(),    
  7.     test_pb:decode(person, Data).   
這樣,很方便代碼整合,只要協議映射好,封包解包就可以統一在網關層處理。

改進空協議

[plain] view plain copy
 在CODE上查看代碼片派生到我的代碼片
  1. message tos{  
  2. }  
友好兼容空結構,原來空協議會報以下的警告信息
[plain] view plain copy
 在CODE上查看代碼片派生到我的代碼片
  1. 2> test_pb:encode_tos(#tos{}).  
  2. <<>>  
  3. 3> c(test_pb).  
  4. src/test_pb.erl:33: Warning: variable 'Record' is unused  
  5. {ok,test_pb}  

改進調用效率

改進了序列化和反序列化的效率,encode測試效率提升10 ~ 20%, decode測試效率提升10% ~ 40%
decode優化較大,實際有些情況不止40%,取均值,部分代碼優化到協議編譯期,所以調用就省事多了。

總結一些效率改進的技巧

獲取record名字

[plain] view plain copy
 在CODE上查看代碼片派生到我的代碼片
  1. [RecName | _] = tuple_to_list(Data)  
  2. 改成了:  
  3. erlang:element(1,Data)  

函數參數匹配優化

[plain] view plain copy
 在CODE上查看代碼片派生到我的代碼片
  1. test(Bytes) when is_binary(Bytes) ->  
  2.     ok.  
  3. 改成了  
  4. test(<<Bytes/binary>>) ->  
  5.     ok.  
當匹配類型多時就會明顯,guard模塊對于多參數或多類型匹配尤為不利,erlang在編譯期不能做優化。

分割二進制

[plain] view plain copy
 在CODE上查看代碼片派生到我的代碼片
  1. Bytes = list_to_binary("0123456789"),  
  2. split_binary(Bytes, 3),  
  3.   
  4. <<B1:3/binary, B2/binary>> = Bytes,%% 測試效率沒erlang:split_binary/2高  
  5. {B1, B2}.  

二進制合并

[plain] view plain copy
 在CODE上查看代碼片派生到我的代碼片
  1. 11> A= <<>>.  
  2. <<>>  
  3. 12> B= <<"1333">>.  
  4. <<"1333">>  
  5. 15> C= <<1,3,4>>.  
  6. <<1,3,4>>  
  7. 16> iolist_to_binary([B,C,A]).  
  8. <<49,51,51,51,1,3,4>>  
  9. 17> <<B/binary,C/binary,A/binary>>.  
  10. <<49,51,51,51,1,3,4>>  
  11. 18> c(loop).  
  12. {ok,loop}  
  13. 19> loop:test().  
  14. 1000000 loops, using time: 281ms  
  15. 1000000 loops, using time: 94ms  

case匹配優化

[plain] view plain copy
 在CODE上查看代碼片派生到我的代碼片
  1. case Data of  
  2.    {double, C} -> ok;  
  3.    {float, C} -> ok;  
  4.    {int, C} -> ok;  
  5.    {string, C} -> ok;  
  6.    _ -> ok  
  7. end  
  8.   
  9. case Data of  
  10.    {C, double} -> ok;  
  11.    {C, float} -> ok;  
  12.    {C, int} -> ok;  
  13.    {C, string} -> ok;  
  14.    _ -> ok  
  15. end  
第一種匹配效率較高,case匹配類似函數參數匹配,固定不變的內容放匹配表達式左邊

比較erlang原生的二進制轉換

最后,比較 erlang:term_to_binary/1 與 erlang:binary_to_term/1 的效率
測試結果發現erlang原生的二進制轉換的效率超高,但是數據沒壓縮,不適合直接使用。實際使用需要配合 zlib:zip/1,這個是壓縮工具,可能還需要稍微優化一下
[plain] view plain copy
 在CODE上查看代碼片派生到我的代碼片
  1. zip(Data) ->  
  2.   Z = zlib:open(),  
  3.   Bs =  
  4.   try  
  5.       zlib:deflateInit(Z, best_speed, deflated, -15, 1, default),  
  6.       B = zlib:deflate(Z, Data, finish),  
  7.       zlib:deflateEnd(Z),  
  8.       B  
  9.   after  
  10.       zlib:close(Z)  
  11.   end,  
  12.   iolist_to_binary(Bs).  
測試結果:
erlang:term_to_binary/1(配合zlib:zip/1)時間開銷比 protobuf 多15%。
erlang:binary_to_term/1(配合zlib:unzip/1)時間開銷差不多是 protobuf 的50%。

項目Git地址:
https://github.com/chenweiqi/erl_protobuffs/

2015/6/11 修復字段默認值沒有生效bug
2015/6/11 修復proto文件換行無法編譯bug
參考:http://blog.csdn.net/mycwq/article/details/42122439

附件下載erl_protobuffs.zip
posted on 2017-03-13 11:47 思月行云 閱讀(1369) 評論(0)  編輯 收藏 引用 所屬分類: Erlang
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产精品红桃| 欧美区在线播放| 国产一二三精品| 欧美一区二区三区男人的天堂| 在线天堂一区av电影| 国产乱子伦一区二区三区国色天香 | 亚洲欧洲午夜| 欧美精品18videos性欧美| 这里只有精品丝袜| 亚洲一区二区影院| 在线观看亚洲视频啊啊啊啊| 国产乱理伦片在线观看夜一区| 久久精品91久久久久久再现| 久久久久www| 一本色道久久综合狠狠躁篇的优点| 亚洲精品影院| 国产一区日韩一区| 欧美激情视频一区二区三区在线播放 | 久久av红桃一区二区小说| 久久精品国产精品亚洲精品| 亚洲成色999久久网站| 亚洲美女网站| 黄色一区二区三区| 亚洲精品视频免费观看| 国产亚洲欧美日韩精品| 亚洲激情在线视频| 国产日韩精品一区观看| 亚洲第一色中文字幕| 国产精品手机在线| 亚洲高清电影| 黄色亚洲精品| 亚洲一区二区三区四区在线观看| 1204国产成人精品视频| 亚洲一区二区四区| 99热免费精品在线观看| 久久精品在线观看| 亚洲欧美国产日韩中文字幕| 六月丁香综合| 久久久蜜桃一区二区人| 国产精品v日韩精品v欧美精品网站| 久热精品在线视频| 国产麻豆午夜三级精品| 亚洲啪啪91| 亚洲国产精品精华液2区45| 欧美一级黄色录像| 亚洲欧美日韩一区在线| 欧美肥婆在线| 你懂的一区二区| 激情婷婷久久| 新狼窝色av性久久久久久| 亚洲香蕉网站| 欧美日本久久| 91久久精品国产91久久性色tv| 狠狠网亚洲精品| 欧美在线观看一区| 久久精品1区| 国产美女诱惑一区二区| 亚洲午夜激情免费视频| 亚洲一区中文| 国产精品久久国产精麻豆99网站| 亚洲精品自在久久| 一区二区日韩欧美| 欧美日韩亚洲网| 99精品国产在热久久| 一本色道久久综合精品竹菊| 欧美激情在线免费观看| 亚洲欧洲一区二区三区| 亚洲毛片视频| 欧美日韩国产探花| 一区二区三区四区五区精品视频| 一区二区欧美亚洲| 国产精品看片你懂得| 亚洲综合色激情五月| 欧美亚洲网站| 亚洲午夜精品17c| 亚洲一区影院| 国精产品99永久一区一区| 久久精品国产亚洲高清剧情介绍| 久久久人成影片一区二区三区| 国产一区av在线| 另类亚洲自拍| 99国产精品久久久久老师| 先锋亚洲精品| 精品9999| 欧美日韩一区二区三区免费| 亚洲婷婷综合久久一本伊一区| 欧美伊久线香蕉线新在线| 在线观看欧美成人| 欧美日韩免费看| 香蕉av福利精品导航| 欧美激情网友自拍| 亚洲自拍偷拍网址| 在线观看日韩av电影| 欧美日韩免费看| 久久精品国产清高在天天线| 亚洲国产日韩综合一区| 小嫩嫩精品导航| 亚洲日韩欧美视频一区| 国产精品试看| 欧美日韩国产成人精品| 欧美专区福利在线| 亚洲另类视频| 欧美肥婆在线| 久久国产毛片| 亚洲一区二区黄色| 亚洲成人在线免费| 国产精品影音先锋| 欧美激情乱人伦| 久久激情综合| 亚洲欧美一区二区视频| 亚洲欧洲一区二区三区久久| 久久精品国产久精国产一老狼| 亚洲精品乱码久久久久久| 国产亚洲午夜高清国产拍精品| 欧美日韩精品欧美日韩精品| 欧美专区在线播放| 亚洲一区二区三区乱码aⅴ| 亚洲激情婷婷| 欧美国产高潮xxxx1819| 卡通动漫国产精品| 久久久精品日韩| 欧美一级视频| 亚洲免费在线视频| 亚洲一级在线| 一本色道**综合亚洲精品蜜桃冫| 在线成人av.com| 国产一区欧美日韩| 国产一区亚洲一区| 国产一区二区三区久久 | 久久婷婷av| 性欧美1819sex性高清| 国产精品99久久久久久久vr| 亚洲人在线视频| 亚洲人成网站影音先锋播放| 1024国产精品| 亚洲国产欧美另类丝袜| 亚洲成在人线av| 亚洲大胆av| 亚洲精品色图| 一本久久综合亚洲鲁鲁五月天| 日韩天堂av| 中日韩美女免费视频网址在线观看 | 欧美在线视频免费观看| 亚洲一区免费网站| 日韩一二在线观看| 一区二区三区欧美| 亚洲一级电影| 亚洲综合色激情五月| 午夜一区二区三区不卡视频| 性欧美1819性猛交| 久久天堂国产精品| 女人色偷偷aa久久天堂| 亚洲黄色一区二区三区| 99精品欧美一区二区三区| 一区二区高清在线| 亚洲与欧洲av电影| 久久久蜜桃精品| 老鸭窝亚洲一区二区三区| 欧美成人亚洲成人| 欧美日韩免费一区二区三区| 欧美性色综合| 韩国在线一区| 亚洲欧洲综合另类| 国产精品99久久久久久白浆小说| 激情欧美一区| 欧美日韩国产在线| 国产精品国产三级国产专播品爱网 | 欧美+亚洲+精品+三区| 亚洲国产成人久久综合| 99国产精品久久久久老师| 性亚洲最疯狂xxxx高清| 蜜臀av一级做a爰片久久| 欧美图区在线视频| 国语自产精品视频在线看8查询8 | 狠狠色丁香久久婷婷综合丁香 | 欧美日韩另类视频| 国产一区二区三区在线观看视频| 亚洲国产三级| 亚洲欧美怡红院| 亚洲国产精品电影| 午夜精品三级视频福利| 欧美激情成人在线| 国产亚洲精品久久飘花| 日韩一区二区免费看| 久久亚洲视频| 99视频日韩| 欧美1级日本1级| 国产欧美精品国产国产专区| 亚洲国产精品美女| 久久精品中文字幕一区| 亚洲精品在线观看视频| 久久久精品欧美丰满| 国产精品丝袜白浆摸在线| 亚洲日本国产| 久热精品视频在线观看| 午夜精品免费| 国产精品看片你懂得| 一本色道久久综合亚洲91| 亚洲电影自拍| 久久免费国产精品1|