新聞中心
TCP/IP是可靠性傳輸協(xié)議,它能保證數(shù)據(jù)能按順序的方式到達(dá)目的地.看到以上描述在寫(xiě)TCP/IP應(yīng)用的時(shí)候似乎就可以放心了,只要程序不出意外就數(shù)據(jù)輸傳就是正確.但最近在做一個(gè)文件傳輸工作的時(shí)候確得到的結(jié)果并不是這樣,發(fā)現(xiàn)網(wǎng)絡(luò)環(huán)境和一次發(fā)送數(shù)據(jù)大會(huì)影響整個(gè)輸傳結(jié)果.以下是這兩晚的測(cè)試情況

公司主營(yíng)業(yè)務(wù):成都網(wǎng)站制作、網(wǎng)站設(shè)計(jì)、外貿(mào)網(wǎng)站建設(shè)、移動(dòng)網(wǎng)站開(kāi)發(fā)等業(yè)務(wù)。幫助企業(yè)客戶(hù)真正實(shí)現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競(jìng)爭(zhēng)能力。成都創(chuàng)新互聯(lián)公司是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊(duì)。公司秉承以“開(kāi)放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對(duì)我們的高要求,感謝他們從不同領(lǐng)域給我們帶來(lái)的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會(huì)用頭腦與智慧不斷的給客戶(hù)帶來(lái)驚喜。成都創(chuàng)新互聯(lián)公司推出龍里免費(fèi)做網(wǎng)站回饋大家。
測(cè)試內(nèi)容描述:
每個(gè)文件塊信息包大概是120k左右
采用異步5連接輸傳,雙方的Socket.SendBufferSize和Socket.ReceiveBufferSize都設(shè)置為64K
測(cè)試服務(wù)器分別有:
局域網(wǎng):ServerA
在美國(guó)機(jī)房:ServerB 延時(shí)高,Ping有時(shí)會(huì)超時(shí)
測(cè)試client一臺(tái),通過(guò)ADSL上網(wǎng).
以下是Client從Sever下載文件的情況:
服務(wù)器8K SendBuffer,客戶(hù)端是8K ReceiveBuffer
從ServerA下載文件,分別下載多個(gè)文件幾M到幾百M(fèi)不等,下載后文件正確.
從ServerB下載文件,分別下載多個(gè)文件,幾M或更小的文件有部分正確,大文件基本都是錯(cuò)誤.兩端記錄的發(fā)送的字節(jié)數(shù)和接收的字節(jié)相等,符合文件大小,程序也沒(méi)有跟蹤到數(shù)據(jù)接收異常導(dǎo)致的協(xié)議分解錯(cuò)誤.
服務(wù)器4K SendBuffer,客戶(hù)端8K ReceiveBuffer
從ServerA下載文件,分別下載多個(gè)文件幾M到幾百M(fèi)不等,下載后文件正確.
從ServerB下載文件,分別下載多個(gè)文件,文件的正確率比較高,不過(guò)還是大文件相對(duì)錯(cuò)誤比較多.當(dāng)開(kāi)啟迅雷下載后情況就開(kāi)始變壞,大部分接收到的文件都出問(wèn)題,兩端記錄的發(fā)送的字節(jié)數(shù)和接收的字節(jié)相等,符合文件大小,程序也沒(méi)有跟蹤到數(shù)據(jù)接收異常導(dǎo)致的協(xié)議分解錯(cuò)誤
服務(wù)器2K SendBuffer,客戶(hù)端8K ReceiveBuffer
從ServerA下載文件,分別下載多個(gè)文件幾M到幾百M(fèi)不等,下載后文件正確.
從ServerB下載文件,分別下載多個(gè)文件,下載結(jié)果沒(méi)有發(fā)現(xiàn)錯(cuò)誤文件.當(dāng)開(kāi)啟迅雷下載后還是有個(gè)別文件錯(cuò)誤,兩端記錄的發(fā)送的字節(jié)數(shù)和接收的字節(jié)相等,符合文件大小,程序也沒(méi)有跟蹤到數(shù)據(jù)接收異常導(dǎo)致的協(xié)議分解錯(cuò)誤
服務(wù)器1K SendBuffer,客戶(hù)端8K ReceiveBuffer
從ServerA下載文件,分別下載多個(gè)文件幾M到幾百M(fèi)不等,下載后文件正確.
從ServerB下載文件,分別下載多個(gè)文件,下載結(jié)果沒(méi)有發(fā)現(xiàn)錯(cuò)誤文件.當(dāng)開(kāi)啟迅雷下載后沒(méi)有發(fā)現(xiàn)文件錯(cuò)誤.
測(cè)試文件發(fā)送到Server和下載的情況基本差不多,這說(shuō)明了在網(wǎng)絡(luò)不好的情況處理發(fā)送大數(shù)據(jù)包似首容易產(chǎn)生錯(cuò)誤,但看TCP/IP協(xié)議講解這情況似乎不存在,因?yàn)楫?dāng)一個(gè)發(fā)送數(shù)據(jù)超過(guò)某個(gè)值的時(shí)候,TCP會(huì)劃分塊進(jìn)行傳輸并保證其順序.但網(wǎng)絡(luò)不好的情況測(cè)試結(jié)果接收的數(shù)據(jù)有錯(cuò)誤,但處理的數(shù)據(jù)大小是正確的,也并沒(méi)影響整個(gè)協(xié)議的分解.由于對(duì)CP/IP協(xié)議、低層和路由處理的不了解,暫沒(méi)找到具體原因。。。不排除程序存在還沒(méi)發(fā)現(xiàn)的錯(cuò)誤,打算給發(fā)送的文件數(shù)據(jù)加上校驗(yàn)再測(cè)試一下看情況
補(bǔ)充一下
以上測(cè)試只修改了一個(gè)屬性
TcpUtils.SendBufferLength = 1K,2K,4K,8K
但只有1K的測(cè)試結(jié)果奇怪地沒(méi)出現(xiàn)文件錯(cuò)誤,其了幾中均出現(xiàn)僅僅是對(duì)ServerB,對(duì)ServerA來(lái)說(shuō)沒(méi)有出現(xiàn),2K,4K也只是開(kāi)啟迅雷的時(shí)候錯(cuò)誤情況多.
網(wǎng)站名稱(chēng):解決C#Socket發(fā)送數(shù)據(jù)大小問(wèn)題
文章起源:http://www.5511xx.com/article/dhddedc.html


咨詢(xún)
建站咨詢(xún)
