開放式系統(tǒng)互聯(lián)是把網(wǎng)絡通信的工作分為7層,分別是物理層,數(shù)據(jù)鏈路層,網(wǎng)絡層,傳輸層,會話層,表示層和應用層。
意為開放式系統(tǒng)互聯(lián)。國際標準組織(國際標準化組織)制定了OSI(Open System Interconnection)模型。這個模型把網(wǎng)絡通信的工作分為7層,分別是物理層,數(shù)據(jù)鏈路層,網(wǎng)絡層,傳輸層,會話層,表示層和應用層。1至4層被認為是低層,這些層與數(shù)據(jù)移動密切相關。5至7層是高層,包含應用程序級的數(shù)據(jù)。每一層負責一項具體的工作,然后把數(shù)據(jù)傳送到下一層。
學習OSI模型中最重要的事情是它實際代表什么意思。假如你是一個網(wǎng)絡上的操作系統(tǒng)。在1層和2層工作的網(wǎng)卡將通知你什么時候有數(shù)據(jù)到達。驅(qū)動程序處理2層幀的出口,通過它你可以得到一個發(fā)亮和閃光的3層數(shù)據(jù)包(希望是如此)。作為操作系統(tǒng),你將調(diào)用一些常用的應用程序處理3層數(shù)據(jù)。
如果這個數(shù)據(jù)是從下面發(fā)上來的,你知道那是發(fā)給你的數(shù)據(jù)包,或者那是一個廣播數(shù)據(jù)包(除非你同時也是一個路由器,不過,暫時不用擔心這個問題)。如果你決定保留這個數(shù)據(jù)包,你將打開它,并且取出4層數(shù)據(jù)包。如果它是TCP協(xié)議,這個TCP子系統(tǒng)將被調(diào)用并打開這個數(shù)據(jù)包,然后把這個7層數(shù)據(jù)發(fā)送給在目標端口等待的應用程序。這個過程就結(jié)束了。當要對網(wǎng)絡上的其它計算機做出回應的時候,每一件事情都以相反的順序發(fā)生。7層應用程序?qū)褦?shù)據(jù)發(fā)送給TCP協(xié)議的執(zhí)行者。
然后,TCP協(xié)議在這些數(shù)據(jù)中加入額外的文件頭。在這個方向上,數(shù)據(jù)每前進一步體積都要大一些。TCP協(xié)議在IP協(xié)議中加入一個合法的TCP字段。然后,IP協(xié)議把這個數(shù)據(jù)包交給以太網(wǎng)。以太網(wǎng)再把這個數(shù)據(jù)作為一個以太網(wǎng)幀發(fā)送給驅(qū)動程序。然后,這個數(shù)據(jù)通過了這個網(wǎng)絡。這條線路中的路由器將部分地分解這個數(shù)據(jù)包以獲得3層文件頭,以便確定這個數(shù)據(jù)包應該發(fā)送到哪里。如果這個數(shù)據(jù)包的目的地是本地以太網(wǎng)子網(wǎng),這個操作系統(tǒng)將代替路由器為計算機進行地址解析,并且把數(shù)據(jù)直接發(fā)送給主機。
第1層是物理層(Physical Laye)(也即OSI模型中的第一層)在課堂上經(jīng)常是被忽略的。它看起來似乎很簡單。但是,這一層的某些方面有時需要特別留意。物理層實際上就是布線、光纖、網(wǎng)卡和其它用來把兩臺網(wǎng)絡通信設備連接在一起的東西。甚至一個信鴿也可以被認為是一個1層設備。網(wǎng)絡故障的排除經(jīng)常涉及到1層問題。我們不能忘記用五類線在整個一層樓進行連接的傳奇故事。由于辦公室的椅子經(jīng)常從電纜線上壓過,導致網(wǎng)絡連接出現(xiàn)斷斷續(xù)續(xù)的情況。遺憾的是,這種故障是很常見的,而且排除這種故障需要耗費很長時間。第2層是數(shù)據(jù)鏈路層(Data Link Layer)運行以太網(wǎng)等協(xié)議。請記住,我們要使這個問題簡單一些。第2層中最重要的是你應該理解網(wǎng)橋是什么。交換機可以看成網(wǎng)橋,人們都這樣稱呼它。網(wǎng)橋都在2層工作,僅關注以太網(wǎng)上的MAC地址。如果你在談論有關MAC地址、交換機或者網(wǎng)卡和驅(qū)動程序,你就是在第2層的范疇。集線器屬于第1層的領域,因為它們只是電子設備,沒有2層的知識。第2層的相關問題在本網(wǎng)絡講座中有自己的一部分,因此先不詳細討論這個問題的細節(jié)。只需要知道第2層把數(shù)據(jù)幀轉(zhuǎn)換成二進制位供1層處理就可以了。第3層是網(wǎng)絡層(Network Layer)在計算機網(wǎng)絡中進行通信的兩個計算機之間可能會經(jīng)過很多個數(shù)據(jù)鏈路,也可能還要經(jīng)過很多通信子網(wǎng)。網(wǎng)絡層的任務就是選擇合適的網(wǎng)間路由和交換結(jié)點, 確保數(shù)據(jù)及時傳送。網(wǎng)絡層將數(shù)據(jù)鏈路層提供的幀組成數(shù)據(jù)包,包中封裝有網(wǎng)絡層包頭,其中含有邏輯地址信息- -源站點和目的站點地址的網(wǎng)絡地址。如果你在談論一個IP地址,那么你是在處理第3層的問題,這是“數(shù)據(jù)包”問題,而不是第2層的“幀”。IP是第3層問題的一部分,此外還有一些路由協(xié)議和地址解析協(xié)議(ARP)。有關路由的一切事情都在第3層處理。地址解析和路由是3層的重要目的。第4層是處理信息的傳輸層(Transport Layer)。第4層的數(shù)據(jù)單元也稱作數(shù)據(jù)包(packets)。但是,當你談論TCP等具體的協(xié)議時又有特殊的叫法,TCP的數(shù)據(jù)單元稱為段(segments)而UDP協(xié)議的數(shù)據(jù)單元稱為“數(shù)據(jù)報(datagrams)”。這個層負責獲取全部信息,因此,它必須跟蹤數(shù)據(jù)單元碎片、亂序到達的數(shù)據(jù)包和其它在傳輸過程中可能發(fā)生的危險。理解第4層的另一種方法是,第4層提供端對端的通信管理。像TCP等一些協(xié)議非常善于保證通信的可靠性。有些協(xié)議并不在乎一些數(shù)據(jù)包是否丟失,UDP協(xié)議就是一個主要例子。第5層是會話層( Session Layer)這一層也可以稱為會晤層或?qū)υ拰樱跁拰蛹耙陨系母邔哟沃?,?shù)據(jù)傳送的單位不再另外命名,統(tǒng)稱為報文。會話層不參與具體的傳輸,它提供包括訪問驗證和會話管理在內(nèi)的建立和維護應用之間通信的機制。如服務器驗證用戶登錄便是由會話層完成的。第6層是表示層(Presentation Layer)這一層主要解決用戶信息的語法表示問題。它將欲交換的數(shù)據(jù)從適合于某一用戶的抽象語法,轉(zhuǎn)換為適合于OSI系統(tǒng)內(nèi)部使用的傳送語法。即提供格式化的表示和轉(zhuǎn)換數(shù)據(jù)服務。數(shù)據(jù)的壓縮和解壓縮, 加密和解密等工作都由表示層負責。第7層是“一切”。第7層也稱作“應用層”(Application Layer),是專門用于應用程序的。應用層確定進程之間通信的性質(zhì)以滿足用戶需要以及提供網(wǎng)絡與用戶應用軟件之間的接口服務。如果你的程序需要一種具體格式的數(shù)據(jù),你可以發(fā)明一些你希望能夠把數(shù)據(jù)發(fā)送到目的地的格式,并且創(chuàng)建一個第7層協(xié)議。SMTP、DNS和FTP都是7層協(xié)議。