TCP傳輸協(xié)議中如何解決丟包問(wèn)題?
回答這個(gè)問(wèn)題之前,要從以下兩個(gè)方面去排查:一、TCP協(xié)議為什么會(huì)丟包,在什么樣的情況下會(huì)丟包。
1、TCP協(xié)議定義(Transimission Control Protocol)是以一種面向連接的、可靠的、基于字節(jié)流的傳輸層通信協(xié)議。
2、TCP是基于不可靠的網(wǎng)路實(shí)現(xiàn)可靠傳輸,肯定會(huì)存在丟包問(wèn)題。
3、如果在通信過(guò)程中,發(fā)現(xiàn)缺少數(shù)據(jù)或者丟包,那邊么最大的可能性是程序發(fā)送過(guò)程或者接受過(guò)程中出現(xiàn)問(wèn)題。
舉個(gè)栗子:假如我有2臺(tái)服務(wù)器 ,a和b服務(wù)器。
a服務(wù)器發(fā)送數(shù)據(jù)給B服務(wù)器頻率過(guò)高時(shí),b服務(wù)器來(lái)不及處理,造成數(shù)據(jù)丟包。(原因可能是程序邏輯問(wèn)題,多線程同步問(wèn)題,緩沖區(qū)溢出問(wèn)題)
如果a服務(wù)器不對(duì)發(fā)送頻率進(jìn)行控制,或者數(shù)據(jù)進(jìn)行重發(fā)的話,那么b服務(wù)器收到數(shù)據(jù)就會(huì)少。就會(huì)造成丟失數(shù)據(jù)
二、TCP協(xié)議丟包后,如何解決丟包的問(wèn)題為了滿足TCP協(xié)議不丟包。TCP協(xié)議有如下規(guī)定
1、數(shù)據(jù)分片:發(fā)送端對(duì)數(shù)據(jù)進(jìn)行分片,接受端要對(duì)數(shù)據(jù)進(jìn)行重組,由TCP確定分片的大小并控制分片和重組
2、到達(dá)確認(rèn):接收端接收到分片數(shù)據(jù)時(shí),根據(jù)分片數(shù)據(jù)序號(hào)向發(fā)送端發(fā)送一個(gè)確認(rèn)
3、超時(shí)重發(fā):發(fā)送方在發(fā)送分片時(shí)設(shè)置超時(shí)定時(shí)器,如果在定時(shí)器超時(shí)之后沒(méi)有收到相應(yīng)的確認(rèn),重發(fā)分片數(shù)據(jù)
4、滑動(dòng)窗口:TCP連接的每一方的接受緩沖空間大小固定,接收端只允許另一端發(fā)送接收端緩沖區(qū)所能接納的數(shù)據(jù),TCP在滑動(dòng)窗口的基礎(chǔ)上提供流量控制,防止較快主機(jī)致使較慢主機(jī)的緩沖區(qū)溢出
5、失序處理:作為IP數(shù)據(jù)報(bào)來(lái)傳輸?shù)腡CP分片到達(dá)時(shí)可能會(huì)失序,TCP將對(duì)收到的數(shù)據(jù)進(jìn)行重新排序,將收到的數(shù)據(jù)以正確的順序交給應(yīng)用層;
6、重復(fù)處理:作為IP數(shù)據(jù)報(bào)來(lái)傳輸?shù)腡CP分片會(huì)發(fā)生重復(fù),TCP的接收端必須丟棄重復(fù)的數(shù)據(jù);
7、數(shù)據(jù)校驗(yàn):TCP將保持它首部和數(shù)據(jù)的檢驗(yàn)和,這是一個(gè)端到端的檢驗(yàn)和,目的是檢測(cè)數(shù)據(jù)在傳輸過(guò)程中的任何變化。如果收到分片的檢驗(yàn)或有差錯(cuò),TCP將丟棄這個(gè)分片,并不確認(rèn)收到此報(bào)文段導(dǎo)致對(duì)端超時(shí)并重發(fā)
TCP三次握手,四次釋放圖: