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

Fork me on GitHub
隨筆 - 215  文章 - 13  trackbacks - 0
<2016年11月>
303112345
6789101112
13141516171819
20212223242526
27282930123
45678910


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

常用鏈接

留言簿(1)

隨筆分類

隨筆檔案

相冊

Awesome

Blog

Book

GitHub

Link

搜索

  •  

積分與排名

  • 積分 - 221316
  • 排名 - 117

最新評論

閱讀排行榜

http://blog.csdn.net/u014630768/article/details/34895367

UDT庫 https://sourceforge.net/projects/udt/?source=directory

    C#包裝:https://github.com/dump247/udt-net

    

  • UDT協(xié)議是什么?是一種基于UDP的數(shù)據(jù)傳輸協(xié)議(UDP-based Data Transfer Protocol,簡稱UDT)。

  • UDT協(xié)議的主要作用是什么?UDT的主要目的是支持高速廣域網(wǎng)上的海量數(shù)據(jù)傳輸,而互聯(lián)網(wǎng)上的標準數(shù)據(jù)傳輸協(xié)議TCP在高帶寬長距離網(wǎng)絡上性能很差。

  • 那么UDT與UDP的區(qū)別又是什么?UDT建于UDP之上,并引入新的擁塞控制和數(shù)據(jù)可靠性控制機制。UDT是面向連接的雙向的應用層協(xié)議。它同時支持可靠的數(shù)據(jù)流傳輸和部分可靠的數(shù)據(jù)報傳輸。

  • UDT的使用場景是什么?由于UDT完全在UDP上實現(xiàn),它也可以應用在除了高速數(shù)據(jù)傳輸之外的其它應用領域,例如點到點技術(P2P),防火墻穿透,多媒體數(shù)據(jù)傳輸?shù)鹊取?/span>

    (以上問題的答案均摘自wikipedia)當然我今天也不是來當知識搬運工的,而是結合以上UDT協(xié)議的基本定義來深入到UDT協(xié)議內部去解析它。


    UDT協(xié)議的主要特性有哪些?

  • 基于UDP的應用層協(xié)議: 有基本網(wǎng)絡知識的朋友都知道TCP和UDP的區(qū)別和使用場景,但是有沒有一種協(xié)議能同時兼顧TCP協(xié)議的安全可靠和UDP協(xié)議的高效,那么UDT就是一種。

  • 面向連接的協(xié)議:面向連接意味著兩個使用協(xié)議的應用在彼此交換數(shù)據(jù)之前必須先建立一個連接,當然UDT是邏輯上存在的連接通道。這種連接的維護是基于握手、Keep-alive(保活)以及關閉連接。

  • 可靠的協(xié)議:依靠包序號機制、接收者的ACK響應和丟包報告、ACK序號機制、重傳機制(基于丟包報告和超時處理)來實現(xiàn)數(shù)據(jù)傳輸?shù)目煽啃浴?/span>

  • 雙工的協(xié)議:每個UDT實例包含發(fā)送端和接收端的信息。

  • 單播的數(shù)據(jù)流。

  • 新的擁塞算法,并且具有可擴展的擁塞控制框架:新的擁塞控制算法不同于基于窗口的TCP擁塞控制算法(慢啟動和擁塞避免),是混合的基于窗口的、基于速率的擁塞控制算法。可擴展的擁塞控制框架開源的代碼和擁塞控制的C++類架構,可支持開發(fā)者派生專用的擁塞控制算法。

  • 帶寬估計:UDT使用對包(PP -- Packet pair)的機制來估計帶寬值。即每16個包為一組,最后一個是對包,即發(fā)送方不用等到下一個發(fā)送周期內再發(fā)送。接收方接收到對包后對其到達時間進行記錄,可結合上次記錄的值計算出鏈路的帶寬(計算的方法稱為中值過濾法), 并在下次ACK中進行反饋。


★★★ENET庫(photon的可靠udp) https://github.com/lsalzman/enet

c#包裝1:https://github.com/RainsSoft/enetcs

c#包裝2:https://github.com/RainsSoft/ENetSharp

大家都知道UDP這個東西太不可靠了,存在著亂序,丟包,包重復等缺點,但它的速度快,包有界等優(yōu)點,但在實際編程中要自己處理亂序啊之類的問題會發(fā)瘋 的。也許大家說用TCP就得了,第一點TCP的速度比較慢,第二個TCP是一個數(shù)據(jù)流一樣的東西,我們要傳數(shù)據(jù)的話還得處理數(shù)據(jù)的分界問題,也挺麻煩的。

針對這個問題,ENET這個庫實現(xiàn)了一個性能介于TCP與UDP之間,完成可靠(不丟包,按序),保持數(shù)據(jù)的分界的優(yōu)點。編程起來也挺方便的。

下載地址:http://enet.bespin.org/SourceDistro.html


RakNet庫  https://github.com/OculusVR/RakNet

c#包裝:https://github.com/RainsSoft/RakNet-C-Sharp-binding-project

RakNet是一個基于UDP網(wǎng)絡傳輸協(xié)議的C++網(wǎng)絡庫,允許程序員在他們自己的程序中實現(xiàn)高效的網(wǎng)絡傳輸服務。通常情況下用于游戲,但也可以用于其它項目。

RakNet有以下特點:

l 高性能 在同一臺計算機上,RakNet可以實現(xiàn)在兩個程序之間每秒傳輸25,000條信息;

l 容易使用 RakNet有在線用戶手冊,視頻教程。每一個函數(shù)和類都有詳細的講解,每一個功能都有自己的例程;

l 跨平臺,當前RakNet支持Windows, Linux, Macs,可以建立在Visual Studio, GCC, Code,Blocks, DevCPP 和其它平臺上。

l 在線技術支持 RakNet有一個活躍的論壇,郵件列表,你只要給他們發(fā)信,他們可以在幾小時之內回復你。

l 安全的傳輸 RakNet在你的代碼中自動使用SHA1, AES128, SYN,用RSA避免傳輸受到攻擊

l 音頻傳輸 用Speex編碼解碼,8位的音頻只需要每秒500字節(jié)傳輸。

l 遠程終端 用RakNet,你能遠程管理你的程序,包括程序的設置,密碼的管理和日志的管理。

l 目錄服務器 目錄服務器允許服務器列舉他們自己需要的客戶端,并與他們連接。

l Autopatcher Autopatcher系統(tǒng)將限制客戶端傳輸?shù)椒斩说奈募@樣是為了避免一些不合法的用戶將一些不合法的文件傳輸?shù)椒斩恕?/span>

l 對象重載系統(tǒng)

l 網(wǎng)絡數(shù)據(jù)壓縮 BitStream類允許壓縮矢量,矩陣,四元數(shù)和在-1到1之間的實數(shù)。

l 遠程功能調用

l 強健的通信層 可以保障信息按照不同的信道傳輸


UDT基于一種基于帶寬速率控制的擁塞控制算法進行設計,主要用在小數(shù)量的bulk源共享富裕帶寬的情況下,最典型的例子就是建立在光纖廣域網(wǎng)上的網(wǎng)格計算,而在ISP提供帶寬有限的情況下運行卻顯得消耗資源并性能不足。甚至可能被防火墻,或ISP服務商判斷為惡意帶寬使用攻擊。

RakNet是為游戲應用而設計,對于實時性等游戲相關的網(wǎng)絡需求有很好的支持,對于大批量數(shù)據(jù)傳輸卻有點力所不及。raknet的缺點是不支持組播


★★★★ KCP - A Fast and Reliable ARQ Protocol

源碼: https://github.com/skywind3000/kcp

c#包裝:https://github.com/RainsSoft/kcp-csharp

KCP是一個快速可靠協(xié)議,能以比 TCP浪費10%-20%的帶寬的代價,換取平均延遲降低 30%-40%,且最大延遲降低三倍的傳輸效果。純算法實現(xiàn),并不負責底層協(xié)議(如UDP)的收發(fā),需要使用者自己定義下層數(shù)據(jù)包的發(fā)送方式,以 callback的方式提供給 KCP。 連時鐘都需要外部傳遞進來,內部不會有任何一次系統(tǒng)調用。

整個協(xié)議只有 ikcp.h, ikcp.c兩個源文件,可以方便的集成到用戶自己的協(xié)議棧中。也許你實現(xiàn)了一個P2P,或者某個基于 UDP的協(xié)議,而缺乏一套完善的ARQ可靠協(xié)議實現(xiàn),那么簡單的拷貝這兩個文件到現(xiàn)有項目中,稍微編寫兩行代碼,即可使用。

KCP協(xié)議比較

如果網(wǎng)絡從來不丟包,那么你直接用 TCP就行了,甚至直接裸UDP都沒關系,但是網(wǎng)絡因為丟包造成卡頓,特別是高峰時期丟包會上到10%的情況,移動設備上這個情況更糟糕。

我自己評測過很多,asio_kcp 的作者做過比較詳細的評測,在網(wǎng)絡變糟糕的情況下,KCP的延遲比 libenet低三倍以上:

worst network lag happen: asio: 10:51.21 291  295   269   268   231   195   249   230   225   204  enet: 10:51.21 1563   1520    1470    1482    1438    1454    1412    1637    1588    1540

更詳細的評測可以看這里:benchmark,感謝 asio_kcp 的作者 zhangyuan 詳細對比了 UDT, libenet和 kcp,并給出結論如下:

  • ASIO-KCP has good performace in wifi and phone network(3G, 4G).
  • The kcp is the first choice for realtime pvp game.
  • The lag is less than 1 second when network lag happen. 3 times better than enet when lag happen.
  • The enet is a good choice if your game allow 2 second lag.
  • UDT is a bad idea. It always sink into badly situation of more than serval seconds lag. And the recovery is not expected.

其他可以左右你選擇的情況:

  • enet has the problem of lack of doc. And it has lots of functions that you may intrest.
  • kcp's doc is chinese.
  • Good thing is the function detail which is writen in code is english. And you can use asio_kcp which is a good wrap.
  • The kcp is a simple thing. You will write more code if you want more feature.
  • UDT has a perfect doc. UDT may has more bug than others as I feeling.

我當年主要測試了 KCP和 TCP/UDT的比較,掃了一眼 libenet覺得協(xié)議實現(xiàn)中規(guī)中矩,缺乏很多現(xiàn)代傳輸協(xié)議的技術,所以并沒有詳細測試。而 asio-kcp的作者同時給出了KCP/enet/udt三者的詳細比較,為猶豫選擇的人提供了更多指引。

The bench mark is for realtime pvp game. For example, the multiplayer first person shooting game.
The requirement of realtime pvp game is packet is small and frequently. 
It wants a minimal delay. And the worst delay should be not so worse. 
The test client send 500 bytes in every 50 milliseconds. And the server send it back after receiving immediately.

Three frameworks were tested,

  • UDT - UDP-based Data Transfer Protocol
  • kcp - A Fast and Reliable ARQ Protocol
  • enet - Reliable UDP networking library


lidgren-network-gen3 

https://github.com/RainsSoft/lidgren-network-gen3

純C#實現(xiàn)的UDP開源庫,可用于游戲,支持NAT,內部使用的可靠ARQ協(xié)議算法沒仔細去研究,不知道WIFI以及3G/4G下的表現(xiàn)怎么樣,暫時沒有測試數(shù)據(jù)

UDT協(xié)議詳解:
http://blog.csdn.net/bytxl/article/details/44979669

RakNet:http://blog.csdn.net/ww506772362/article/details/51076890
ENET庫(可靠UDP):
http://blog.csdn.net/yuanchunsi/article/details/70244338


posted on 2017-12-08 14:32 思月行云 閱讀(7386) 評論(3)  編輯 收藏 引用 所屬分類: C\C++

FeedBack:
# re: 幾種UDP網(wǎng)絡庫的整理Raknet,UDT,ENet,lidgren-network-gen3 2017-12-08 16:02 思月行云
# re: 幾種UDP網(wǎng)絡庫的整理Raknet,UDT,ENet,lidgren-network-gen3 2017-12-08 16:04 思月行云
KCP —— 快速可靠的網(wǎng)絡傳輸協(xié)議
https://www.oschina.net/p/kcp  回復  更多評論
  
# re: 幾種UDP網(wǎng)絡庫的整理Raknet,UDT,ENet,lidgren-network-gen3 2017-12-08 16:17 思月行云
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
              狼狼综合久久久久综合网| 欧美精品91| 噜噜噜在线观看免费视频日韩| 国产精品大全| 欧美在线视频一区二区| 久久久久久999| 亚洲伊人一本大道中文字幕| 久久亚洲私人国产精品va媚药| 夜夜爽av福利精品导航| 亚洲高清不卡在线观看| 亚洲激情婷婷| 免费在线观看一区二区| 亚洲欧美网站| 亚洲天堂久久| 在线综合亚洲欧美在线视频| 亚洲黄色成人| 噜噜噜在线观看免费视频日韩| 亚洲女爱视频在线| 一区二区三区视频在线观看| 亚洲一品av免费观看| 亚洲欧洲美洲综合色网| 亚洲国产天堂久久国产91| 国产精品久久久久一区二区三区共 | 亚洲日本va午夜在线影院| 亚洲精品乱码| 亚洲桃色在线一区| 亚洲天堂成人| 西西人体一区二区| 久久尤物视频| 久久av资源网| 亚洲一区二区在线免费观看视频| 亚洲天堂网在线观看| 99国产精品一区| av成人动漫| 午夜精品久久久久久久99水蜜桃| 日韩午夜电影| 久久婷婷国产综合精品青草| 99re8这里有精品热视频免费| 亚洲国产精品va在看黑人| 亚洲精品看片| 欧美成人蜜桃| 国产在线播放一区二区三区| 亚洲视频在线播放| 久久精品一区二区三区不卡| 亚洲一级黄色av| 久久亚洲精品一区| 午夜精品福利视频| 欧美日韩中文| 国产一区二区三区久久| 日韩视频免费在线观看| 亚洲新中文字幕| 日韩午夜在线观看视频| 免费观看30秒视频久久| 国产一区二区三区网站| 亚洲午夜高清视频| 久久天天狠狠| 午夜精品福利电影| 国产综合欧美在线看| 免费永久网站黄欧美| 欧美在线免费视屏| 国产精品久久久爽爽爽麻豆色哟哟| 亚洲二区在线视频| 亚洲男人av电影| 久久久无码精品亚洲日韩按摩| 一区二区三区波多野结衣在线观看| 卡一卡二国产精品| 狠狠色狠狠色综合日日五| 性欧美video另类hd性玩具| 亚洲精品在线免费观看视频| 免费观看欧美在线视频的网站| 国产美女精品一区二区三区 | 欧美午夜欧美| 欧美国产日韩一区二区| 欧美一区激情| 亚洲电影免费| 99视频精品全部免费在线| 欧美日韩国产欧美日美国产精品| 黄色成人av网站| 亚洲欧美日韩精品在线| 欧美一进一出视频| 久久国产精彩视频| 欧美99在线视频观看| 久久精品久久99精品久久| 国产精品h在线观看| 久久久国产精品亚洲一区| 久久一区二区三区av| 亚洲免费观看高清完整版在线观看熊 | 国产精品久久久久久久久免费| 亚洲激情影视| 一区二区三区视频在线| 伊伊综合在线| 久久久久久久综合日本| 亚洲欧美激情视频在线观看一区二区三区 | 国产尤物精品| 欧美大片网址| 精品粉嫩aⅴ一区二区三区四区| 一区二区三区导航| 在线观看欧美视频| 久久精品系列| 久久久久99| 黄色成人av网站| aa级大片欧美| 久久精品国产99国产精品| 欧美日韩精品在线视频| 亚洲乱码国产乱码精品精98午夜| 欧美一级视频| 国产麻豆午夜三级精品| 久久国产色av| 欧美风情在线| 亚洲午夜国产一区99re久久| 久久视频一区二区| 亚洲第一福利在线观看| 亚洲人成人一区二区三区| 午夜精品国产精品大乳美女| 欧美承认网站| 国内精品视频久久| 欧美不卡视频一区发布| 亚洲精品日韩在线观看| 午夜精品福利在线| 有坂深雪在线一区| 性欧美xxxx视频在线观看| 欧美xx视频| 久久精品女人天堂| 亚洲专区一区| 欧美午夜a级限制福利片| 性亚洲最疯狂xxxx高清| 一区二区av| 亚洲成人在线网站| 亚洲一区在线免费| 黄色av一区| 国产欧美丝祙| 国产精品久久久一区麻豆最新章节| 一区二区三区国产盗摄| 亚洲人成7777| 亚洲激情综合| 免费一级欧美片在线观看| 亚洲尤物精选| 亚洲视频视频在线| 在线观看亚洲视频| 国产精品日本欧美一区二区三区| 久久久精品国产一区二区三区| 欧美日韩免费在线视频| 亚洲尤物视频网| 亚洲婷婷国产精品电影人久久| 国产日韩精品在线| 国产精品成人免费| 欧美精品久久一区| 久久一本综合频道| 亚洲黄色影院| 亚洲精品久久久久| 午夜视频久久久| 亚洲男人第一网站| 欧美一区精品| 欧美日韩一区二区三区在线看| 欧美国产亚洲视频| 欧美xx69| 欧美视频中文字幕在线| 国产婷婷色一区二区三区在线| 国产精品久久一级| 欧美精品国产精品日韩精品| 久久久噜噜噜久噜久久| 久久色在线观看| 国产九九精品视频| 国产亚洲欧美一区二区三区| 国内精品美女在线观看| 91久久精品美女| 亚洲国内精品| 亚洲成人在线视频播放| 亚洲免费网址| 亚洲精品乱码久久久久久蜜桃91| 一区二区三区国产在线观看| 在线观看欧美激情| 亚洲一区二区免费| 欧美视频在线免费| 亚洲精品自在久久| 麻豆精品国产91久久久久久| 亚洲免费观看高清完整版在线观看| 99精品视频一区| 欧美日韩黄色一区二区| 狠狠爱综合网| 久久激情视频久久| 欧美一区二区三区男人的天堂 | 亚洲一区二区精品在线| 亚洲人成绝费网站色www| 亚洲欧美日韩国产精品 | 亚洲乱码久久| 亚洲国产精品999| 久久久久久久久蜜桃| 国产精品av久久久久久麻豆网| 一区二区三区欧美在线| 亚洲天堂av电影| 欧美日本韩国一区| 亚洲婷婷国产精品电影人久久| 欧美wwwwww| 欧美日韩亚洲一区二区| 亚洲精品在线观看免费| 亚洲深夜av| 好吊妞这里只有精品| 亚洲人成网站精品片在线观看 | 久久精品国产99国产精品|