五分鐘內了解OSI 模型

2022.12.18

五分鐘內了解OSI 模型

當你需要描述網絡架構或排除網絡問題時,OSI 模型的相關知識會對你有所幫助。我希望本文能令你對這個模型的方方面面有清晰的理解。

開放系統互聯(OSI)模型是一個定義計算機、服務器和用戶如何在一個系統內通信的標準。它是第一個網絡通信標準模型,在上世紀80 年代早期,所有主流的計算機和通信公司都採用了這個標準。

OSI 模型提供了一種用於描述網絡的通用語言,並以離散的塊或層的方式來描述。

OSI 模型的各個層

該模型描述了計算機系統通過網絡進行通信的七個層。

7 應用層

6 表示層

5 會話層

4 傳輸層

3 網絡層

2 數據鏈路層

1 物理層

每個層都有自己的工作方式和一系列跟其他層不同的協議。本文將逐個剖析這些層級。

應用層

應用層是在軟件中實現的。它是與應用程序交互的層級。

用發送消息作為例子。發送消息的程序與應用層進行交互,並發送消息。接著,應用層向OSI 模型的下一個層級(即表示層)發送消息。

表示層

來自應用層的數據被轉發到表示層。表示層接收到文字、字符、字母、數字等形式的數據,並把它們轉換為機器可識讀的二進制格式數據。這個過程叫做編譯。

在此階段,ASCII(美國信息交換標準碼)字符被轉換為擴充的二進制編碼的十進制交換碼(EBCDIC)。轉換後的數據在繼續傳輸前,也會進行編碼和加密過程,使用SSL 協議進行加密和解密。

表示層的作用是抽象化,它假設下面的層級會處理它們收到的數據。它也負責壓縮數據。數據的壓縮可能是有損的,也有可能是無損的,這取決於很多因素,這不屬於本文的討論範圍。

會話層

會話層的作用是建立和管理連接。該層級的主要工作是建立會話。例如,你登錄網上商城,就在你的機器和服務器之間建立了會話。

會話層的作用是實現數據的發送和接收,完成後連接的會話就終止了。在一個會話建立前,會進行身份驗證。與上一層類似,會話層也假設在它的工作完成後,下面的層級也會準確無誤地處理數據。

傳輸層

傳輸層的作用是管理數據傳輸和其自身的關於數據如何傳輸的一些協議。從會話層傳到這裡的數據被分為更小的數據單元,這些數據單元稱為片段。這個過程叫做“分段”。每個片段包含來源端口號、目標端口號和一個序列號。端口號用來識別發送數據的應用程序。注意,數據以塊的形式傳輸。序列號用於把這些片段按正確的順序排列。

傳輸層負責控制流量或在給定的時間內傳輸的數據量。它也負責錯誤控制,比如數據丟失、損壞等情況。它利用一種錯誤檢測值,通常叫做校驗和。傳輸層對每個數據片段加上校驗和,就可以檢查所發送的數據是否被正確接收。然後數據傳輸到網絡層。

網絡層

網絡層的作用是跟其他網絡進行通信。它把從一台機器接收到的數據片段傳輸給另一台位於不同網絡的機器。路由器是作用於網絡層的。

網絡層的功能是邏輯尋址(就是確定IP 地址)。它為發送方和接收方分配IP 地址,數據包附帶了這個地址,就可以被傳輸到正確的目標機器。接著網絡層對數據包進行路由。負載均衡也是在網絡層進行的,旨在確保不會發生過載。下一步,數據傳輸到數據鏈路層。

數據鏈路層

數據鏈路層支持跟其他設備直接通信。

它接收到來自網絡層、包含發送方和接收方IP 地址的數據包,進行物理尋址,然後將發送方和接收方的MAC 地址分配給數據包,形成幀。

物理層

物理層由系統的所有硬件和物理設備(包括網線、導航系統、適配器等)組成。在這裡,從前面層級接收到的數據都是0 和1 形式的。物理層把這些數據轉換並通過各種方式(如果是光纖電纜,有電線、電信號、光信號;如果是WIFI,則為無線電信號)傳輸至本地媒介。

注意,物理層作用於接收方的一端,把接收到的信號以幀的形式傳輸到數據鏈路層(把它轉換回二進制數據形式)。然後幀傳輸到上面的層級,最終應用層(應用軟件)會接收到需要的數據。

結語

當你需要描述網絡架構或排除網絡問題時,OSI 模型的相關知識會對你有所幫助。我希望本文能令你對這個模型的方方面面有清晰的理解。