www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當前位置:首頁 > 技術(shù)學(xué)院 > 基礎(chǔ)知識科普站
[導(dǎo)讀]可靠性TCP提供一種面向連接的、可靠的字節(jié)流服務(wù)。面向連接意味著兩個使用TCP的應(yīng)用(通常是一個客戶和一個服務(wù)器)在彼此交換數(shù)據(jù)包之前必須先建立一個TCP連接。這一過程與打電話很相似,先撥號振鈴,等待對方摘機說“喂”,然后才說明是誰。在一個TCP連接中,僅有兩方進行彼此通信。廣播和多播不能用于TCP。

可靠性TCP提供一種面向連接的、可靠的字節(jié)流服務(wù)。面向連接意味著兩個使用TCP的應(yīng)用(通常是一個客戶和一個服務(wù)器)在彼此交換數(shù)據(jù)包之前必須先建立一個TCP連接。這一過程與打電話很相似,先撥號振鈴,等待對方摘機說“喂”,然后才說明是誰。在一個TCP連接中,僅有兩方進行彼此通信。廣播和多播不能用于TCP。

TCP協(xié)議可靠性及重傳策略實現(xiàn)

TCP通過下列方式來提供可靠性:

1.應(yīng)用數(shù)據(jù)被分割成TCP認為最適合發(fā)送的數(shù)據(jù)塊。這和UDP完全不同,應(yīng)用程序產(chǎn)生的數(shù)據(jù)長度將保持不變。由TCP傳遞給IP的信息單位稱為報文段或段(segment)。2.當TCP發(fā)出一個段后,它啟動一個定時器,等待目的端確認收到這個報文段。如果不能及時收到一個確認,將重發(fā)這個報文段。當TCP收到發(fā)自TCP連接另一端的數(shù)據(jù),它將發(fā)送一個確認。TCP有延遲確認的功能,在此功能沒有打開,則是立即確認。功能打開,則由定時器觸發(fā)確認時間點。3.TCP將保持它首部和數(shù)據(jù)的檢驗和。這是一個端到端的檢驗和,目的是檢測數(shù)據(jù)在傳輸過程中的任何變化。如果收到段的檢驗和有差錯,TCP將丟棄這個報文段和不確認收到此報文段(希望發(fā)端超時并重發(fā))。4.既然TCP報文段作為IP數(shù)據(jù)報來傳輸,而IP數(shù)據(jù)報的到達可能會失序,因此TCP報文段的到達也可能會失序。如果必要,TCP將對收到的數(shù)據(jù)進行重新排序,將收到的數(shù)據(jù)以正確的順序交給應(yīng)用層。5.既然IP數(shù)據(jù)報會發(fā)生重復(fù),TCP的接收端必須丟棄重復(fù)的數(shù)據(jù)。6.TCP還能提供流量控制。TCP連接的每一方都有固定大小的緩沖空間。TCP的接收端只允許另一端發(fā)送接收端緩沖區(qū)所能接納的數(shù)據(jù)。這將防止較快主機致使較慢主機的緩沖區(qū)溢出。兩個應(yīng)用程序通過TCP連接交換8bit字節(jié)構(gòu)成的字節(jié)流。TCP不在字節(jié)流中插入記錄標識符。我們將這稱為字節(jié)流服務(wù)(bytestreamservice)。如果一方的應(yīng)用程序先傳10字節(jié),又傳20字節(jié),再傳50字節(jié),連接的另一方將無法了解發(fā)方每次發(fā)送了多少字節(jié)。只要自己的接收緩存沒有塞滿,TCP 接收方將有多少就收多少。一端將字節(jié)流放到TCP連接上,同樣的字節(jié)流將出現(xiàn)在TCP連接的另一端。另外,TCP對字節(jié)流的內(nèi)容不作任何解釋。TCP不知道傳輸?shù)臄?shù)據(jù)字節(jié)流是二進制數(shù)據(jù),還是ASCⅡ字符、EBCDIC字符或者其他類型數(shù)據(jù)。對字節(jié)流的解釋由TCP連接雙方的應(yīng)用層解釋。

這種對字節(jié)流的處理方式與Unix操作系統(tǒng)對文件的處理方式很相似。Unix的內(nèi)核對一個應(yīng)用讀或?qū)懙膬?nèi)容不作任何解釋,而是交給應(yīng)用程序處理。對Unix的內(nèi)核來說,它無法區(qū)分一個二進制文件與一個文本文件。

重傳策略TCP協(xié)議用于控制數(shù)據(jù)段是否需要重傳的依據(jù)是設(shè)立重發(fā)定時器。在發(fā)送一個數(shù)據(jù)段的同時啟動一個重傳,如果在重傳超時前收到確認(Acknowlegement)就關(guān)閉該重傳,如果重傳超時前沒有收到確認,則重傳該數(shù)據(jù)段。在選擇重發(fā)時間的過程中,TCP必須具有自適應(yīng)性。它需要根據(jù)互聯(lián)網(wǎng)當時的通信情況,給出合適的重發(fā)時間。這種重傳策略的關(guān)鍵是對定時器初值的設(shè)定。采用較多的算法是Jacobson于1988年提出的一種不斷調(diào)整超時時間間隔的動態(tài)算法。其工作原理是:對每條連接TCP都保持一個變量RTT(Round Trip Time),用于存放當前到目的端往返所需要時間最接近的估計值。當發(fā)送一個數(shù)據(jù)段時,同時啟動連接的定時器,如果在定時器超時前確認到達,則記錄所需要的時間(M),并修正RTT的值,如果定時器超時前沒有收到確認,則將RTT的值增加1倍。通過測量一系列的RTT(往返時間)值,TCP協(xié)議可以估算數(shù)據(jù)包重發(fā)前需要等待的時間。在估計該連接所需的當前延遲時通常利用一些統(tǒng)計學(xué)的原理和算法(如Karn算法),從而得到TCP重發(fā)之前需要等待的時間值。

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

在工業(yè)自動化領(lǐng)域,Modbus協(xié)議憑借其開放性和易用性成為設(shè)備通信的"通用語言"。然而,當工程師面對Modbus RTU、ASCII和TCP三種變體時,如何根據(jù)具體場景做出最優(yōu)選擇?本文將從編碼機制、通信效率、錯誤檢測等...

關(guān)鍵字: Modbus協(xié)議 TCP

TCP/IP(Transmission Control Protocol/Internet Protocol,傳輸控制協(xié)議/網(wǎng)際協(xié)議)是指能夠在多個不同網(wǎng)絡(luò)間實現(xiàn)信息傳輸?shù)膮f(xié)議簇。TCP/IP協(xié)議不僅僅指的是TCP 和I...

關(guān)鍵字: TCP IP

把TCP首部想象成一封信的信封,每個字段對應(yīng)信封上的不同信息。源端口和目的端口就像寄信人和收信人的門牌號,序列號和確認號相當于書信的頁碼編號和回執(zhí)編號。數(shù)據(jù)偏移量可以比作信封上留出的貼郵票位置,保留字段就像信封上預(yù)留的空...

關(guān)鍵字: TCP 首部信息

Socket接收隊列是內(nèi)核中為每個Socket維護的一個緩沖區(qū),用于臨時存儲接收到的UDP數(shù)據(jù)包。它的存在使得應(yīng)用程序可以異步地處理網(wǎng)絡(luò)數(shù)據(jù),同時提供了流量控制的能力(通過丟棄隊滿時的數(shù)據(jù)包)。理解接收隊列的工作原理對于...

關(guān)鍵字: socket UDP

從通信原理看,UDP上的SIP消息解析是應(yīng)用層對無連接、不可靠傳輸層的數(shù)據(jù)報進行結(jié)構(gòu)化解析的過程。每個UDP數(shù)據(jù)報包含一個完整的SIP消息,解析器需要按照SIP協(xié)議規(guī)范將字節(jié)流轉(zhuǎn)換為結(jié)構(gòu)化的消息對象,然后根據(jù)消息類型進行...

關(guān)鍵字: socket UDP

如何在同一個Go程序中監(jiān)聽多個UDP端口,解析SIP消息,并根據(jù)來源端口進行不同的處理邏輯。需要結(jié)合并發(fā)編程、SIP協(xié)議解析和消息轉(zhuǎn)發(fā)機制來實現(xiàn)這一需求。

關(guān)鍵字: socket UDP

三次握手的目的,確保雙方都能正常通信,確認雙方的發(fā)送和接收能力正常??赡芘e一個生活中的例子,比如打電話時的確認過程。

關(guān)鍵字: TCP 通信

服務(wù)器接收請求是一個涉及網(wǎng)絡(luò)層(IP/端口綁定)、傳輸層(UDP/TCP/TLS 適配)、應(yīng)用層(SIP 協(xié)議解析)

關(guān)鍵字: 服務(wù)器 TCP UDP

在TCP(傳輸控制協(xié)議)網(wǎng)絡(luò)通信中,粘包問題一直是開發(fā)者需要面對和解決的難題。TCP粘包,即發(fā)送方多次寫入的數(shù)據(jù)在接收方被讀取時,多個數(shù)據(jù)包粘合在一起,導(dǎo)致接收方難以正確解析和處理數(shù)據(jù)。這種問題的出現(xiàn),主要源于TCP的傳...

關(guān)鍵字: TCP 粘包

在Linux內(nèi)核中,網(wǎng)絡(luò)丟包是指由于網(wǎng)絡(luò)傳輸過程中出現(xiàn)問題,導(dǎo)致數(shù)據(jù)包未能成功到達目的地。這可能由多種原因引起,包括網(wǎng)絡(luò)擁塞、硬件故障、錯誤配置等。當發(fā)生網(wǎng)絡(luò)丟包時,應(yīng)用程序可能會受到影響,例如導(dǎo)致數(shù)據(jù)傳輸延遲或失敗。為...

關(guān)鍵字: UDP Linux
關(guān)閉