tcp丟包重發(fā) TCP傳輸協(xié)議中如何解決丟包問題?
TCP傳輸協(xié)議中如何解決丟包問題?怎么解決TCP網(wǎng)絡(luò)傳輸“粘包”問題?首先,TCP是一種流協(xié)議,不存在粘貼數(shù)據(jù)包的情況。簡而言之,TCP保證發(fā)送方按照接收方接收字節(jié)流的順序發(fā)送字節(jié)流,否則會由于網(wǎng)絡(luò)超
TCP傳輸協(xié)議中如何解決丟包問題?
怎么解決TCP網(wǎng)絡(luò)傳輸“粘包”問題?
首先,TCP是一種流協(xié)議,不存在粘貼數(shù)據(jù)包的情況。
簡而言之,TCP保證發(fā)送方按照接收方接收字節(jié)流的順序發(fā)送字節(jié)流,否則會由于網(wǎng)絡(luò)超時而返回錯誤。這是由操作系統(tǒng)保證的,應(yīng)用程序根本無法控制。
主要問題是發(fā)送方應(yīng)該以什么格式發(fā)送數(shù)據(jù),接收方可以正確解析數(shù)據(jù)。這稱為應(yīng)用層協(xié)議,由您決定。它與TCP無關(guān)。如果發(fā)送一個文件,最簡單的方法就是用HTTP協(xié)議封裝它。如果您發(fā)送的HTTP協(xié)議數(shù)據(jù)是100%正確的,那么無論哪個接收器(nginx/Tomcat/IIS)都保證正確接收字節(jié),因為HTTP協(xié)議本身有一個頭和一個體。頭中的content length:12345指定了主體的大小,主體是文件本身。
您不需要HTTP協(xié)議來直接發(fā)送文件數(shù)據(jù),所以問題是,接收者如何知道在文件結(jié)束之前應(yīng)該接收多少字節(jié)?主要的方法是發(fā)送方暫停0.1秒,這樣如果接收方?jīng)]有收到0.1秒,他就認(rèn)為文件已經(jīng)收到了。這個方法是一個拼寫概率。假設(shè)是千兆網(wǎng)絡(luò),就不可能適應(yīng)不同的網(wǎng)絡(luò)。
文檔中還有一個明確的語句,send和recv的返回值表示成功發(fā)送/接收的字節(jié)數(shù)。原始文檔的具體描述如下:
send(2)up成功完成后,返回發(fā)送的字節(jié)數(shù)。否則,返回-1,全局變量errno設(shè)置為指示錯誤。
recv(2)這些調(diào)用返回接收的字節(jié)數(shù),如果發(fā)生錯誤,則返回-1。還沒完成?繼續(xù)前進(jìn)。沒收它?堅持下去。你怎么知道結(jié)束了?一個特殊的內(nèi)容被同意代表結(jié)束,或者一個長度被同意首先被發(fā)送。對?多收費(fèi)?你怎么知道還有多少?