當前位置:首頁 > 嵌入式 > 嵌入式教程
[導讀]讀者一定都聽說過著名的OSI協(xié)議參考模型,它是基于國際標準化組織(ISO)的建議發(fā)展起來的,從上到下共分為7層:應用層、表示層、會話層、傳輸層、網(wǎng)絡層、數(shù)據(jù)鏈路層及物理層。這個7層的協(xié)議模型雖然規(guī)定得非常細致和完善,但在實際中卻得不到廣泛的應用,其重要的原因之一就在于它過于復雜。

10.1TCP/IP協(xié)議概述10.1.1OSI參考模型及TCP/IP參考模型

讀者一定都聽說過著名的OSI協(xié)議參考模型,它是基于國際標準化組織(ISO)的建議發(fā)展起來的,從上到下共分為7層:應用層、表示層、會話層、傳輸層、網(wǎng)絡層、數(shù)據(jù)鏈路層及物理層。這個7層的協(xié)議模型雖然規(guī)定得非常細致和完善,但在實際中卻得不到廣泛的應用,其重要的原因之一就在于它過于復雜。但它仍是此后很多協(xié)議模型的基礎,這種分層架構(gòu)的思想在很多領(lǐng)域都得到了廣泛的應用。

與此相區(qū)別的TCP/IP協(xié)議模型從一開始就遵循簡單明確的設計思路,它將TCP/IP的7層協(xié)議模型簡化為4層,從而更有利于實現(xiàn)和使用。TCP/IP的協(xié)議參考模型和OSI協(xié)議參考模型的對應關(guān)系如圖10.1所示。

圖10.1OSI模型和TCP/IP參考模型對應關(guān)系

下面分別對TCP/IP的4層模型進行簡要介紹。

n 網(wǎng)絡接口層:負責將二進制流轉(zhuǎn)換為數(shù)據(jù)幀,并進行數(shù)據(jù)幀的發(fā)送和接收。要注意的是數(shù)據(jù)幀是獨立的網(wǎng)絡信息傳輸單元。

n 網(wǎng)絡層:負責將數(shù)據(jù)幀封裝成IP數(shù)據(jù)包,并運行必要的路由算法。

n 傳輸層:負責端對端之間的通信會話連接與建立。傳輸協(xié)議的選擇根據(jù)數(shù)據(jù)傳輸方式而定。

n 應用層:負責應用程序的網(wǎng)絡訪問,這里通過端口號來識別各個不同的進程。

10.1.2TCP/IP協(xié)議族

雖然TCP/IP名稱只包含了兩個協(xié)議,但實際上,TCP/IP是一個龐大的協(xié)議族,它包括了各個層次上的眾多協(xié)議,圖10.2列舉了各層中一些重要的協(xié)議,并給出了各個協(xié)議在不同層次中所處的位置,如下所示。

n ARP:用于獲得同一物理網(wǎng)絡中的硬件主機地址。

n MPLS:多協(xié)議標簽協(xié)議,是很有發(fā)展前景的下一代網(wǎng)絡協(xié)議。

n IP:負責在主機和網(wǎng)絡之間尋址和路由數(shù)據(jù)包。

n ICMP:用于發(fā)送有關(guān)數(shù)據(jù)包的傳送錯誤的協(xié)議。

n IGMP:被IP主機用來向本地多路廣播路由器報告主機組成員的協(xié)議。

n TCP:為應用程序提供可靠的通信連接。適合于一次傳輸大批數(shù)據(jù)的情況。并適用于要求得到響應的應用程序。

n UDP:提供了無連接通信,且不對傳送包進行可靠性保證。適合于一次傳輸少量數(shù)據(jù),可靠性則由應用層來負責。

10.1.3TCP和UDP

在此主要介紹在網(wǎng)絡編程中涉及的傳輸層TCP和UDP協(xié)議。

1.TCP

(1)概述。

同其他任何協(xié)議棧一樣,TCP向相鄰的高層提供服務。因為TCP的上一層就是應用層,因此,TCP數(shù)據(jù)傳輸實現(xiàn)了從一個應用程序到另一個應用程序的數(shù)據(jù)傳遞。應用程序通過編程調(diào)用TCP并使用TCP服務,提供需要準備發(fā)送的數(shù)據(jù),用來區(qū)分接收數(shù)據(jù)應用的目的地址和端口號。

通常應用程序通過打開一個socket來使用TCP服務,TCP管理到其他socket的數(shù)據(jù)傳遞。可以說,通過IP的源/目的可以惟一地區(qū)分網(wǎng)絡中兩個設備的連接,通過socket的源/目的可以惟一地區(qū)分網(wǎng)絡中兩個應用程序的連接。

(2)三次握手協(xié)議。

TCP對話通過三次握手來進行初始化。三次握手的目的是使數(shù)據(jù)段的發(fā)送和接收同步,告訴其他主機其一次可接收的數(shù)據(jù)量,并建立虛連接。

下面描述了這三次握手的簡單過程。

n 初始化主機通過一個同步標志置位的數(shù)據(jù)段發(fā)出會話請求。

n 接收主機通過發(fā)回具有以下項目的數(shù)據(jù)段表示回復:同步標志置位、即將發(fā)送的數(shù)據(jù)段的起始字節(jié)的順序號、應答并帶有將收到的下一個數(shù)據(jù)段的字節(jié)順序號。

n 請求主機再回送一個數(shù)據(jù)段,并帶有確認順序號和確認號。

圖10.3就是這個流程的簡單示意圖。

圖10.3TCP三次握手協(xié)議

TCP實體所采用的基本協(xié)議是滑動窗口協(xié)議。當發(fā)送方傳送一個數(shù)據(jù)報時,它將啟動計時器。當該數(shù)據(jù)報到達目的地后,接收方的TCP實體往回發(fā)送一個數(shù)據(jù)報,其中包含有一個確認序號,它表示希望收到的下一個數(shù)據(jù)包的順序號。如果發(fā)送方的定時器在確認信息到達之前超時,那么發(fā)送方會重發(fā)該數(shù)據(jù)包。

(3)TCP數(shù)據(jù)包頭。

圖10.4給出了TCP數(shù)據(jù)包頭的格式。

TCP數(shù)據(jù)包頭的含義如下所示。

n 源端口、目的端口:16位長。標識出遠端和本地的端口號。

圖10.4TCP數(shù)據(jù)包頭的格式

n 序號:32位長。標識發(fā)送的數(shù)據(jù)報的順序。

n 確認號:32位長。希望收到的下一個數(shù)據(jù)包的序列號。

n TCP頭長:4位長。表明TCP頭中包含多少個32位字。

n 6位未用。

n ACK:ACK位置1表明確認號是合法的。如果ACK為0,那么數(shù)據(jù)報不包含確認信息,確認字段被省略。

n PSH:表示是帶有PUSH標志的數(shù)據(jù)。接收方因此請求數(shù)據(jù)包一到便將其送往應用程序而不必等到緩沖區(qū)裝滿時才傳送。

n RST:用于復位由于主機崩潰或其他原因而出現(xiàn)的錯誤連接。還可以用于拒絕非法的數(shù)據(jù)包或拒絕連接請求。

n SYN:用于建立連接。

n FIN:用于釋放連接。

n 窗口大小:16位長。窗口大小字段表示在確認了字節(jié)之后還可以發(fā)送多少個字節(jié)。

n 校驗和:16位長。是為了確保高可靠性而設置的。它校驗頭部、數(shù)據(jù)和偽TCP頭部之和。

n 可選項:0個或多個32位字。包括最大TCP載荷,滑動窗口比例以及選擇重發(fā)數(shù)據(jù)包等選項。

2.UDP

(1)概述。

UDP即用戶數(shù)據(jù)報協(xié)議,它是一種無連接協(xié)議,因此不需要像TCP那樣通過三次握手來建立一個連接。同時,一個UDP應用可同時作為應用的客戶或服務器方。由于UDP協(xié)議并不需要建立一個明確的連接,因此建立UDP應用要比建立TCP應用簡單得多。

UDP協(xié)議從問世至今已經(jīng)被使用了很多年,雖然其最初的光彩已經(jīng)被一些類似協(xié)議所掩蓋,但是在網(wǎng)絡質(zhì)量越來越高的今天,UDP的應用得到了大大的增強。它比TCP協(xié)議更為高效,也能更好地解決實時性的問題。如今,包括網(wǎng)絡視頻會議系統(tǒng)在內(nèi)的眾多的客戶/服務器模式的網(wǎng)絡應用都使用UDP協(xié)議。

(2)UDP數(shù)據(jù)報頭。

UDP數(shù)據(jù)報頭如下圖10.5所示。

n 源地址、目的地址:16位長。標識出遠端和本地的端口號。

n 數(shù)據(jù)報的長度是指包括報頭和數(shù)據(jù)部分在內(nèi)的總的字節(jié)數(shù)。因為報頭的長度是固定的,所以該域主要用來計算可變長度的數(shù)據(jù)部分(又稱為數(shù)據(jù)負載)。

3.協(xié)議的選擇

協(xié)議的選擇應該考慮到以下3個方面。

(1)對數(shù)據(jù)可靠性的要求。

對數(shù)據(jù)要求高可靠性的應用需選擇TCP協(xié)議,如驗證、密碼字段的傳送都是不允許出錯的,而對數(shù)據(jù)的可靠性要求不那么高的應用可選擇UDP傳送。

(2)應用的實時性。

TCP協(xié)議在傳送過程中要使用三次握手、重傳確認等手段來保證數(shù)據(jù)傳輸?shù)目煽啃?。使用TCP協(xié)議會有較大的時延,因此不適合對實時性要求較高的應用,如VOIP、視頻監(jiān)控等。相反,UDP協(xié)議則在這些應用中能發(fā)揮很好的作用。

(3)網(wǎng)絡的可靠性。

由于TCP協(xié)議的提出主要是解決網(wǎng)絡的可靠性問題,它通過各種機制來減少錯誤發(fā)生的概率。因此,在網(wǎng)絡狀況不是很好的情況下需選用TCP協(xié)議(如在廣域網(wǎng)等情況),但是若在網(wǎng)絡狀況很好的情況下(如局域網(wǎng)等)就不需要再采用TCP協(xié)議,而建議選擇UDP協(xié)議來減少網(wǎng)絡負荷。

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

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務中斷的風險,如企業(yè)系統(tǒng)復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉