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

牽著老婆滿街逛

嚴以律己,寬以待人. 三思而后行.
GMail/GTalk: yanglinbo#google.com;
MSN/Email: tx7do#yahoo.com.cn;
QQ: 3 0 3 3 9 6 9 2 0 .

TCP傳輸小數據包效率問題

轉載自:http://blog.csdn.net/stamhe/archive/2009/09/19/4569530.aspx


TCP傳輸小數據包效率問題(譯自MSDN)

http://www.ftpff.com/blog/?q=node/16

摘要:當使用TCP傳輸小型數據包時,程序的設計是相當重要的。如果在設計方案中不對TCP數據包的延遲應答,Nagle算法,Winsock緩沖作用引起重視,將會嚴重影響程序的性能。這篇文章討論了這些問題,列舉了兩個案例,給出了一些傳輸小數據包的優化設計方案。

背景:當Microsoft TCP棧接收到一個數據包時,會啟動一個200毫秒的計時器。當ACK確認數據包發出之后,計時器會復位,接收到下一個數據包時,會再次啟動200毫秒的計時器。為了提升應用程序在內部網和Internet上的傳輸性能,Microsoft TCP棧使用了下面的策略來決定在接收到數據包后什么時候發送ACK確認數據包:
1、如果在200毫秒的計時器超時之前,接收到下一個數據包,則立即發送ACK確認數據包。
2、如果當前恰好有數據包需要發給ACK確認信息的接收端,則把ACK確認信息附帶在數據包上立即發送。
3、當計時器超時,ACK確認信息立即發送。
為了避免小數據包擁塞網絡,Microsoft TCP棧默認啟用了Nagle算法,這個算法能夠將應用程序多次調用Send發送的數據拼接起來,當收到前一個數據包的ACK確認信息時,一起發送出去。下面是Nagle算法的例外情況:
1、如果Microsoft TCP棧拼接起來的數據包超過了MTU值,這個數據會立即發送,而不等待前一個數據包的ACK確認信息。在以太網中,TCP的MTU(Maximum Transmission Unit)值是1460字節。
2、如果設置了TCP_NODELAY選項,就會禁用Nagle算法,應用程序調用Send發送的數據包會立即被投遞到網絡,而沒有延遲。
為了在應用層優化性能,Winsock把應用程序調用Send發送的數據從應用程序的緩沖區復制到Winsock內核緩沖區。Microsoft TCP棧利用類似Nagle算法的方法,決定什么時候才實際地把數據投遞到網絡。內核緩沖區的默認大小是8K,使用SO_SNDBUF選項,可以改變Winsock內核緩沖區的大小。如果有必要的話,Winsock能緩沖大于SO_SNDBUF緩沖區大小的數據。在絕大多數情況下,應用程序完成Send調用僅僅表明數據被復制到了Winsock內核緩沖區,并不能說明數據就實際地被投遞到了網絡上。唯一一種例外的情況是:通過設置SO_SNDBUT為0禁用了Winsock內核緩沖區。

Winsock使用下面的規則來向應用程序表明一個Send調用的完成:
1、如果socket仍然在SO_SNDBUF限額內,Winsock復制應用程序要發送的數據到內核緩沖區,完成Send調用。
2、如果Socket超過了SO_SNDBUF限額并且先前只有一個被緩沖的發送數據在內核緩沖區,Winsock復制要發送的數據到內核緩沖區,完成Send調用。
3、如果Socket超過了SO_SNDBUF限額并且內核緩沖區有不只一個被緩沖的發送數據,Winsock復制要發送的數據到內核緩沖區,然后投遞數據到網絡,直到Socket降到SO_SNDBUF限額內或者只剩余一個要發送的數據,才完成Send調用。

案例1
一個Winsock TCP客戶端需要發送10000個記錄到Winsock TCP服務端,保存到數據庫。記錄大小從20字節到100字節不等。對于簡單的應用程序邏輯,可能的設計方案如下:
1、客戶端以阻塞方式發送,服務端以阻塞方式接收。
2、客戶端設置SO_SNDBUF為0,禁用Nagle算法,讓每個數據包單獨的發送。
3、服務端在一個循環中調用Recv接收數據包。給Recv傳遞200字節的緩沖區以便讓每個記錄在一次Recv調用中被獲取到。

性能:
在測試中發現,客戶端每秒只能發送5條數據到服務段,總共10000條記錄,976K字節左右,用了半個多小時才全部傳到服務器。

分析:
因為客戶端沒有設置TCP_NODELAY選項,Nagle算法強制TCP棧在發送數據包之前等待前一個數據包的ACK確認信息。然而,客戶端設置SO_SNDBUF為0,禁用了內核緩沖區。因此,10000個Send調用只能一個數據包一個數據包的發送和確認,由于下列原因,每個ACK確認信息被延遲200毫秒:
1、當服務器獲取到一個數據包,啟動一個200毫秒的計時器。
2、服務端不需要向客戶端發送任何數據,所以,ACK確認信息不能被發回的數據包順路攜帶。
3、客戶端在沒有收到前一個數據包的確認信息前,不能發送數據包。
4、服務端的計時器超時后,ACK確認信息被發送到客戶端。

如何提高性能:
在這個設計中存在兩個問題。第一,存在延時問題。客戶端需要能夠在200毫秒內發送兩個數據包到服務端。因為客戶端默認情況下使用Nagle算法,應該使用默認的內核緩沖區,不應該設置SO_SNDBUF為0。一旦TCP棧拼接起來的數據包超過MTU值,這個數據包會立即被發送,不用等待前一個ACK確認信息。第二,這個設計方案對每一個如此小的的數據包都調用一次Send。發送這么小的數據包是不很有效率的。在這種情況下,應該把每個記錄補充到100字節并且每次調用Send發送80個記錄。為了讓服務端知道一次總共發送了多少個記錄,客戶端可以在記錄前面帶一個頭信息。

案例二:
一個Winsock TCP客戶端程序打開兩個連接和一個提供股票報價服務的Winsock TCP服務端通信。第一個連接作為命令通道用來傳輸股票編號到服務端。第二個連接作為數據通道用來接收股票報價。兩個連接被建立后,客戶端通過命令通道發送股票編號到服務端,然后在數據通道上等待返回的股票報價信息。客戶端在接收到第一個股票報價信息后發送下一個股票編號請求到服務端。客戶端和服務端都沒有設置SO_SNDBUF和TCP_NODELAY選項。

性能:
測試中發現,客戶端每秒只能獲取到5條報價信息。

分析:

這個設計方案一次只允許獲取一條股票信息。第一個股票編號信息通過命令通道發送到服務端,立即接收到服務端通過數據通道返回的股票報價信息。然后,客戶端立即發送第二條請求信息,send調用立即返回,發送的數據被復制到內核緩沖區。然而,TCP棧不能立即投遞這個數據包到網絡,因為沒有收到前一個數據包的ACK確認信息。200毫秒后,服務端的計時器超時,第一個請求數據包的ACK確認信息被發送回客戶端,客戶端的第二個請求包才被投遞到網絡。第二個請求的報價信息立即從數據通道返回到客戶端,因為此時,客戶端的計時器已經超時,第一個報價信息的ACK確認信息已經被發送到服務端。這個過程循環發生。

如何提高性能:
在這里,兩個連接的設計是沒有必要的。如果使用一個連接來請求和接收報價信息,股票請求的ACK確認信息會被返回的報價信息立即順路攜帶回來。要進一步的提高性能,客戶端應該一次調用Send發送多個股票請求,服務端一次返回多個報價信息。如果由于某些特殊原因必須要使用兩個單向的連接,客戶端和服務端都應該設置TCP_NODELAY選項,讓小數據包立即發送而不用等待前一個數據包的ACK確認信息。

提高性能的建議:
上面兩個案例說明了一些最壞的情況。當設計一個方案解決大量的小數據包發送和接收時,應該遵循以下的建議:
1、如果數據片段不需要緊急傳輸的話,應用程序應該將他們拼接成更大的數據塊,再調用Send。因為發送緩沖區很可能被復制到內核緩沖區,所以緩沖區不應該太大,通常比8K小一點點是很有效率的。只要Winsock內核緩沖區得到一個大于MTU值的數據塊,就會發送若干個數據包,剩下最后一個數據包。發送方除了最后一個數據包,都不會被200毫秒的計時器觸發。
2、如果可能的話,避免單向的Socket數據流接連。
3、不要設置SO_SNDBUF為0,除非想確保數據包在調用Send完成之后立即被投遞到網絡。事實上,8K的緩沖區適合大多數情況,不需要重新改變,除非新設置的緩沖區經過測試的確比默認大小更高效。
4、如果數據傳輸不用保證可靠性,使用UDP。


posted on 2011-01-13 16:00 楊粼波 閱讀(1678) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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黑人| 香港久久久电影| 欧美成人免费全部| 亚洲一区免费观看| 激情久久一区| 欧美日产国产成人免费图片| 亚洲专区欧美专区| 欧美黄污视频| 校园春色综合网| 亚洲丰满少妇videoshd| 欧美日韩亚洲高清| 久久阴道视频| 一区二区三区欧美视频| 久久人人爽人人爽爽久久| 日韩视频免费看| 国产欧美日韩综合一区在线观看| 六月婷婷一区| 午夜精品福利一区二区三区av| 欧美电影免费观看大全| 午夜精品免费视频| 亚洲精品一区二区网址| 国产女主播一区二区三区| 欧美国产日韩在线| 久久精品91久久香蕉加勒比| 日韩视频一区二区| 亚洲大片在线| 久久国产免费看| 亚洲视频欧洲视频| 亚洲国产精品一区二区第四页av| 国产精品久久网| 欧美国产日韩精品| 久久精品视频在线播放| 亚洲一级免费视频| 99re6热在线精品视频播放速度| 久久尤物视频| 久久成人一区| 亚洲欧美另类久久久精品2019| 最新国产拍偷乱拍精品 | 国产精品日韩专区| 欧美成人免费小视频| 久久99在线观看| 亚洲综合好骚| 亚洲视频一起| 一区二区成人精品| 亚洲乱码国产乱码精品精98午夜| 欧美激情精品久久久久久黑人| 久久久97精品| 久久精品青青大伊人av| 亚洲欧美综合精品久久成人| 99精品国产热久久91蜜凸| 91久久在线观看| 亚洲国产三级| 亚洲国产精品久久久久久女王| 国产一区二区三区四区五区美女 | 夜夜嗨网站十八久久| 亚洲欧洲视频在线| 亚洲国产成人久久综合| 亚洲第一精品夜夜躁人人爽 | 亚洲国产精品一区二区第四页av| 久久久蜜臀国产一区二区| 久久福利影视| 久久精品女人的天堂av| 久久精品欧美| 久久综合久久综合这里只有精品 | 亚洲国产毛片完整版| 黄色亚洲精品| 欲色影视综合吧| 亚洲黄色影院| 亚洲区免费影片| 一本色道久久综合亚洲精品不卡| 亚洲狠狠丁香婷婷综合久久久| 亚洲国产乱码最新视频| 亚洲精品影视在线观看| 一区二区三区欧美成人| 亚洲午夜精品久久| 欧美夜福利tv在线| 久久婷婷色综合| 欧美国产在线观看| 亚洲三级国产| 国产精品99久久久久久久久| 亚洲先锋成人| 久久福利电影| 欧美大片一区二区三区| 欧美视频1区| 国产一区二区久久| 亚洲福利视频在线| 亚洲视频在线视频| 久久久综合香蕉尹人综合网| 欧美成人dvd在线视频| 亚洲精品视频在线观看网站 | 午夜精品久久久久久久99樱桃| 欧美一级成年大片在线观看| 狂野欧美一区| 国产精品久久久久久久app | 亚洲高清自拍| 亚洲线精品一区二区三区八戒| 欧美一区二区三区免费观看视频| 久久久久久九九九九| 亚洲国产精品久久| 亚洲欧美韩国| 欧美成人一区二区在线| 国产精品久久久久9999吃药| 激情久久综合| 一区二区三区四区蜜桃| 久久久久久久999| 亚洲精品久久久久| 久久国产主播| 国产精品theporn88| 精品动漫3d一区二区三区| 9人人澡人人爽人人精品| 久久国产精品久久久| 亚洲国产一区二区三区在线播 | 久久久久久久综合日本| 欧美日本精品| 黄色国产精品| 午夜精品影院| 亚洲精品永久免费精品| 久久精品人人做人人爽电影蜜月| 欧美日韩一区二区三区四区在线观看 | 91久久香蕉国产日韩欧美9色| 亚洲欧美在线磁力| 亚洲国产精品一区二区第一页| 午夜精品久久久久久久久久久久| 欧美不卡高清| 伊人婷婷欧美激情| 久久精品一区二区三区四区| 99精品热视频只有精品10| 久久在线免费| 黄色成人av在线| 亚欧成人在线| 亚洲午夜国产一区99re久久| 欧美第一黄色网| 亚洲国产成人av好男人在线观看| 久久xxxx| 亚洲综合欧美日韩| 欧美视频一区二| 亚洲精品欧美专区| 亚洲第一二三四五区| 久久久久国产成人精品亚洲午夜| 国产精品久久久久久超碰| 99精品国产一区二区青青牛奶| 欧美激情区在线播放| 久久精品日产第一区二区| 国产日韩成人精品| 久久精品国产精品亚洲精品| 亚洲性xxxx| 国产精品久久久久影院色老大| 亚洲视频成人| 日韩午夜在线视频| 欧美性一二三区| 中文日韩电影网站| 日韩视频亚洲视频| 国产精品扒开腿做爽爽爽软件| 亚洲无线一线二线三线区别av| 亚洲精品久久久久久久久| 欧美精品一区二区视频| 日韩午夜激情| 日韩午夜免费视频| 国产精品久久久久久久久久久久久久 | 久久精品成人一区二区三区| 国产欧美一区二区精品仙草咪| 亚久久调教视频| 欧美在线播放高清精品| 国产午夜精品在线| 久久夜色精品国产| 久久综合久久综合久久综合| 亚洲成人直播| 亚洲人成网在线播放| 欧美日韩国产片| 亚洲欧美日韩中文在线制服| 亚洲欧美大片| 精品二区视频| 亚洲国产精品久久91精品| 欧美日韩午夜剧场| 欧美在线日韩在线| 久久午夜羞羞影院免费观看| 亚洲国产一二三| 日韩一区二区福利| 国产精品亚洲产品| 免费观看久久久4p| 欧美日韩国产一级| 久久xxxx精品视频| 欧美高清在线一区二区| 亚洲女优在线| 久久综合色一综合色88| 99精品欧美一区二区蜜桃免费| 亚洲女优在线|