計算機網路之TCP/IP協議簡介

交给时间發表於2024-09-09

TCP/IP協議

簡介

首先TCP/IP協議不只是表示TCP協議和IP協議兩種協議,而是一個協議簇。協議簇是什麼並不難理解,就是字面意思,一個由多個協議組合而成的集合體,其中最有代表性的就是TCP和IP這兩個協議,除了這兩個還有我們熟知的FTP、UDP等協議。當然我們下面主要介紹的還是這兩位主角TCP和IP協議。

網路分層

網路分層是我們網路傳輸的一個框架,每個層級之間相互合作達到了我們相對迅速、安全的網路傳輸,我們這裡介紹一下ISO組織推出的OSI分層模型。

  • 物理層:該層定義了物理傳輸的介面介質等,用於物理節點之間的傳輸

  • 資料鏈路層:這一層是交換機的工作層級,用來將從物理層接收到的資料進行MAC地址的封裝與解封

    MAC地址就是我們網路的實體地址,是網路卡層級的地址,每個網路卡都有自己的MAC地址

  • 網路層:這一層是路由器的工作層級,該層用來透過IP協議進行封裝或解封資料包

  • 傳輸層:該層定義了我們傳輸資料用的協議以及埠號,將我們的資料包進行分段和傳輸,到目的地地址之後再進行重組,TCP和UDP協議就是在這層發揮作用的

  • 會話層:用來透過傳輸層建立的傳輸通路進行發起或者接收會話請求

  • 表示層:用來將接受的資料轉化成我們使用者能夠識別的東西,反之就是將我們能識別的東西轉化為計算機資料

  • 應用層:該層主要為使用者提供終端網路服務,比如我們進行的網頁瀏覽或者郵件傳輸等,該層是HTTP、FTP等協議發揮作用的地方

IP協議

IP指網際互連協議,Internet Protocol的縮寫,從我們的網路層級上來看,屬於網路層,作用是將我們的資料透過IP協議封裝成資料包的形式或者將資料包拆解提供給資料鏈路層幫助資料傳輸。

現如今我們的網路環境是非常複雜的,網路結構也是百花齊放,每個廠家產的網路裝置、系統等可能就會有協議上的差別,因此IP協議強調了適應性、簡潔性和可操作性,並且在可靠性上做出了一定的讓步,IP不保證可靠性,所傳送分組有可能出現丟失、重複、延遲或亂序等問題。

IP分片

IP包在進行傳輸的過程中,可能會經歷不同的物理網路,受限於網路資料幀的最大傳輸單元,當IP資料包過大時就會將其分組拆分為多個滿足傳輸單元條件的片段,傳輸完畢到達目標主機的時候再進行重組。

IP傳輸主要就是解決兩個問題,一個是分解重組,一個是傳輸,具體細節大家可以再深層次研究研究,此處不過多贅述。

TCP協議

TCP是“Transmission Control Protocol”的簡稱,翻譯過來的意思是“傳輸控制協議”。我們透過上面的介紹可以看出,如果我們直接拿著IP資料包去進行傳輸顯然是非常不可靠的,稍微地一個網路動盪就會導致我接收不到資料包,並且傳送方還不知道。那咋辦呢?

TCP提供的端到端的位元組流傳輸,他為我們的資料建立了一個通道,將資料包以流的形式在他建立的通道中進行傳輸,使得端與端之間的資料傳輸變得可靠起來。那麼他是如何建立與終止這個通道的呢?

三次握手

如圖所示為三次握手的大致流程,三次報文傳輸,三次狀態更新,少一步都會導致連線失敗。三次握手完畢之後就可以進行資料傳輸了。

我們不剖析SYN與ACK的原理,我們看一下括號裡的內容,不難看出,每次資料傳輸其實是基於收到的資料進行一個約定好的處理然後再傳送,就相當於我們對詩,你一句(白日依山盡)我一句(黃河入海流),只有按照約定好的規則去返回我們傳輸的內容才會正常建立連線,所以這種連線方式確實是可靠的。

四次揮手

如圖為四次揮手的大致流程,四次報文傳輸,兩端分別都傳送和接收了一次ACK與FIN報文。FIN報文的意思就是終止傳輸的請求報文,當客戶端申請終止傳輸時,現向服務端傳送一個終止確認,意思就是資料傳輸完畢,請求終止連線,然後服務端收到之後會傳送一個ACK意思是剩餘資料傳輸中,待傳輸結束之後傳送FIN意思是服務端資料傳送完畢申請終止連線,最終客戶端回應一個ACK響應給服務端,說明該連線已關閉。

滑動視窗

TCP滑動視窗是用來控制網路傳輸時的流量的一種協議,該協議支援傳送方在停止並等待確認前傳送多個資料分組,來提高網路吞吐量、資料傳輸效率。

大概意思就是,傳送方要傳送資料,接收方給傳送方一個視窗大小,然後傳送方透過接收方給的視窗大小,對自己的資料流進行分組,按照接收方指定的大小一段一段的傳送,這樣做的好處就是接收方可以透過控制視窗大小的方式來管理傳送方傳送資料的大小,從而避免了傳送方直接將大量資料傳送進來造成的網路擁堵。

傳送方傳送資料時可以不必傳送一批將視窗填滿的資料包,傳送方在慢啟動模式下可以從一個資料包開始,一個一個遞增直到接收方視窗大小的資料包量。

超時重傳

超時重傳機制是TCP可靠性的重要一環,此機制可以將接收方超過一定時間沒收到但是傳送方已傳送的資料進行重發,保證了接收方能更有機會接收到資料。

TCP協議要求傳送方每傳送一個報文段的時候就啟動一個定時器並且等待回應訊息,如果超時就會對該段報文重組並重傳。此機制最難的實現點就是重傳超時時間(RTO)的確認,過大過小都會導致問題出現,太大會導致等待確認時間過長影響吞吐量,而太小會導致頻繁重傳浪費網路資源。所以說RTO的動態確認是很困難的,此處不過多贅述(其實是實力不夠硬T_T)。

總結

TCP/IP協議簇是一個非常巧妙的協議集合,他們分佈在不同的網路層級幫助我們約定、對接、傳輸各種報文、資料包等形式組成的資料。也有不同場景的不同應對協議,比如TCP與UDP的取捨,各有各的好處與使用場景。本篇文章僅僅透過我主觀的理解去介紹了IP與TCP協議的大致情況。更深層次的東西如果有精力的話我們可以一起繼續往深了挖。

感謝各位大佬的光臨,本文重在介紹,若有不對的地方還請麻煩各位大佬指教,感謝。

相關文章