轉(zhuǎn)自(https://www.cnblogs.com/fundebug/p/differences-of-tcp-and-udp.html)
摘要:計算機網(wǎng)絡基礎(chǔ)
引言
網(wǎng)絡協(xié)議是每個前端工程師都必須要掌握的知識屉栓,TCP/IP 中有兩個具有代表性的傳輸層協(xié)議艺晴,分別是 TCP 和 UDP猴凹,本文將介紹下這兩者以及它們之間的區(qū)別旺入。
一、TCP/IP網(wǎng)絡模型
計算機與網(wǎng)絡設(shè)備要相互通信,雙方就必須基于相同的方法。比如,如何探測到通信目標引有、由哪一邊先發(fā)起通信、使用哪種語言進行通信倦逐、怎樣結(jié)束通信等規(guī)則都需要事先確定譬正。不同的硬件、操作系統(tǒng)之間的通信檬姥,所有的這一切都需要一種規(guī)則导帝。而我們就把這種規(guī)則稱為協(xié)議(protocol)。
TCP/IP 是互聯(lián)網(wǎng)相關(guān)的各類協(xié)議族的總稱穿铆,比如:TCP您单,UDP,IP荞雏,F(xiàn)TP虐秦,HTTP,ICMP凤优,SMTP 等都屬于 TCP/IP 族內(nèi)的協(xié)議悦陋。
TCP/IP模型是互聯(lián)網(wǎng)的基礎(chǔ),它是一系列網(wǎng)絡協(xié)議的總稱筑辨。這些協(xié)議可以劃分為四層俺驶,分別為鏈路層、網(wǎng)絡層棍辕、傳輸層和應用層暮现。
- 鏈路層:負責封裝和解封裝IP報文还绘,發(fā)送和接受ARP/RARP報文等。
- 網(wǎng)絡層:負責路由以及把分組報文發(fā)送給目標網(wǎng)絡或主機栖袋。
- 傳輸層:負責對報文進行分組和重組拍顷,并以TCP或UDP協(xié)議格式封裝報文。
- 應用層:負責向用戶提供應用程序塘幅,比如HTTP昔案、FTP、Telnet电媳、DNS踏揣、SMTP等。
在網(wǎng)絡體系結(jié)構(gòu)中網(wǎng)絡通信的建立必須是在通信雙方的對等層進行匾乓,不能交錯捞稿。 在整個數(shù)據(jù)傳輸過程中,數(shù)據(jù)在發(fā)送端時經(jīng)過各層時都要附加上相應層的協(xié)議頭和協(xié)議尾(僅數(shù)據(jù)鏈路層需要封裝協(xié)議尾)部分钝尸,也就是要對數(shù)據(jù)進行協(xié)議封裝,以標識對應層所用的通信協(xié)議搂根。接下去介紹TCP/IP 中有兩個具有代表性的傳輸層協(xié)議----TCP 和 UDP珍促。
二、UDP
UDP協(xié)議全稱是用戶數(shù)據(jù)報協(xié)議剩愧,在網(wǎng)絡中它與TCP協(xié)議一樣用于處理數(shù)據(jù)包猪叙,是一種無連接的協(xié)議。在OSI模型中仁卷,在第四層——傳輸層穴翩,處于IP協(xié)議的上一層。UDP有不提供數(shù)據(jù)包分組锦积、組裝和不能對數(shù)據(jù)包進行排序的缺點芒帕,也就是說,當報文發(fā)送之后丰介,是無法得知其是否安全完整到達的背蟆。
它有以下幾個特點:
1. 面向無連接
首先 UDP 是不需要和 TCP一樣在發(fā)送數(shù)據(jù)前進行三次握手建立連接的,想發(fā)數(shù)據(jù)就可以開始發(fā)送了哮幢。并且也只是數(shù)據(jù)報文的搬運工带膀,不會對數(shù)據(jù)報文進行任何拆分和拼接操作。
具體來說就是:
- 在發(fā)送端橙垢,應用層將數(shù)據(jù)傳遞給傳輸層的 UDP 協(xié)議垛叨,UDP 只會給數(shù)據(jù)增加一個 UDP 頭標識下是 UDP 協(xié)議,然后就傳遞給網(wǎng)絡層了
- 在接收端柜某,網(wǎng)絡層將數(shù)據(jù)傳遞給傳輸層嗽元,UDP 只去除 IP 報文頭就傳遞給應用層敛纲,不會任何拼接操作
2. 有單播,多播还棱,廣播的功能
UDP 不止支持一對一的傳輸方式载慈,同樣支持一對多,多對多珍手,多對一的方式办铡,也就是說 UDP 提供了單播,多播琳要,廣播的功能寡具。
3. UDP是面向報文的
發(fā)送方的UDP對應用程序交下來的報文,在添加首部后就向下交付IP層稚补。UDP對應用層交下來的報文童叠,既不合并,也不拆分课幕,而是保留這些報文的邊界厦坛。因此,應用程序必須選擇合適大小的報文
4. 不可靠性
首先不可靠性體現(xiàn)在無連接上乍惊,通信都不需要建立連接杜秸,想發(fā)就發(fā),這樣的情況肯定不可靠润绎。
并且收到什么數(shù)據(jù)就傳遞什么數(shù)據(jù)撬碟,并且也不會備份數(shù)據(jù),發(fā)送數(shù)據(jù)也不會關(guān)心對方是否已經(jīng)正確接收到數(shù)據(jù)了莉撇。
再者網(wǎng)絡環(huán)境時好時壞呢蛤,但是 UDP 因為沒有擁塞控制,一直會以恒定的速度發(fā)送數(shù)據(jù)棍郎。即使網(wǎng)絡條件不好其障,也不會對發(fā)送速率進行調(diào)整。這樣實現(xiàn)的弊端就是在網(wǎng)絡條件不好的情況下可能會導致丟包涂佃,但是優(yōu)點也很明顯静秆,在某些實時性要求高的場景(比如電話會議)就需要使用 UDP 而不是 TCP。
從上面的動態(tài)圖可以得知巡李,UDP只會把想發(fā)的數(shù)據(jù)報文一股腦的丟給對方抚笔,并不在意數(shù)據(jù)有無安全完整到達。
5. 頭部開銷小侨拦,傳輸數(shù)據(jù)報文時是很高效的殊橙。
UDP 頭部包含了以下幾個數(shù)據(jù):
- 兩個十六位的端口號,分別為源端口(可選字段)和目標端口
- 整個數(shù)據(jù)報文的長度
- 整個數(shù)據(jù)報文的檢驗和(IPv4 可選 字段),該字段用于發(fā)現(xiàn)頭部信息和數(shù)據(jù)中的錯誤
因此 UDP 的頭部開銷小膨蛮,只有八字節(jié)叠纹,相比 TCP 的至少二十字節(jié)要少得多,在傳輸數(shù)據(jù)報文時是很高效的
三敞葛、TCP
當一臺計算機想要與另一臺計算機通訊時誉察,兩臺計算機之間的通信需要暢通且可靠,這樣才能保證正確收發(fā)數(shù)據(jù)惹谐。例如持偏,當你想查看網(wǎng)頁或查看電子郵件時,希望完整且按順序查看網(wǎng)頁氨肌,而不丟失任何內(nèi)容鸿秆。當你下載文件時,希望獲得的是完整的文件怎囚,而不僅僅是文件的一部分卿叽,因為如果數(shù)據(jù)丟失或亂序,都不是你希望得到的結(jié)果恳守,于是就用到了TCP考婴。
TCP協(xié)議全稱是傳輸控制協(xié)議是一種面向連接的、可靠的催烘、基于字節(jié)流的傳輸層通信協(xié)議沥阱,由 IETF 的RFC 793定義。TCP 是面向連接的颗圣、可靠的流協(xié)議喳钟。流就是指不間斷的數(shù)據(jù)結(jié)構(gòu)屁使,你可以把它想象成排水管中的水流在岂。
1. TCP連接過程
如下圖所示,可以看到建立一個TCP連接的過程為(三次握手的過程):
第一次握手
客戶端向服務端發(fā)送連接請求報文段蛮寂。該報文段中包含自身的數(shù)據(jù)通訊初始序號蔽午。請求發(fā)送后,客戶端便進入 SYN-SENT 狀態(tài)酬蹋。
第二次握手
服務端收到連接請求報文段后及老,如果同意連接,則會發(fā)送一個應答范抓,該應答中也會包含自身的數(shù)據(jù)通訊初始序號骄恶,發(fā)送完成后便進入 SYN-RECEIVED 狀態(tài)。
第三次握手
當客戶端收到連接同意的應答后匕垫,還要向服務端發(fā)送一個確認報文僧鲁。客戶端發(fā)完這個報文段后便進入 ESTABLISHED 狀態(tài),服務端收到這個應答后也進入 ESTABLISHED 狀態(tài)寞秃,此時連接建立成功斟叼。
這里可能大家會有個疑惑:為什么 TCP 建立連接需要三次握手,而不是兩次春寿?這是因為這是為了防止出現(xiàn)失效的連接請求報文段被服務端接收的情況朗涩,從而產(chǎn)生錯誤。
2. TCP斷開鏈接
TCP 是全雙工的绑改,在斷開連接時兩端都需要發(fā)送 FIN 和 ACK谢床。
第一次握手
若客戶端 A 認為數(shù)據(jù)發(fā)送完成,則它需要向服務端 B 發(fā)送連接釋放請求绢淀。
第二次握手
B 收到連接釋放請求后萤悴,會告訴應用層要釋放 TCP 鏈接。然后會發(fā)送 ACK 包皆的,并進入 CLOSE_WAIT 狀態(tài)覆履,此時表明 A 到 B 的連接已經(jīng)釋放,不再接收 A 發(fā)的數(shù)據(jù)了费薄。但是因為 TCP 連接是雙向的硝全,所以 B 仍舊可以發(fā)送數(shù)據(jù)給 A。
第三次握手
B 如果此時還有沒發(fā)完的數(shù)據(jù)會繼續(xù)發(fā)送楞抡,完畢后會向 A 發(fā)送連接釋放請求伟众,然后 B 便進入 LAST-ACK 狀態(tài)。
第四次握手
A 收到釋放請求后召廷,向 B 發(fā)送確認應答凳厢,此時 A 進入 TIME-WAIT 狀態(tài)。該狀態(tài)會持續(xù) 2MSL(最大段生存期竞慢,指報文段在網(wǎng)絡中生存的時間先紫,超時會被拋棄) 時間,若該時間段內(nèi)沒有 B 的重發(fā)請求的話筹煮,就進入 CLOSED 狀態(tài)遮精。當 B 收到確認應答后,也便進入 CLOSED 狀態(tài)败潦。
3. TCP協(xié)議的特點
-
面向連接
面向連接本冲,是指發(fā)送數(shù)據(jù)之前必須在兩端建立連接。建立連接的方法是“三次握手”劫扒,這樣能建立可靠的連接檬洞。建立連接,是為數(shù)據(jù)的可靠傳輸打下了基礎(chǔ)沟饥。
僅支持單播傳輸
每條TCP傳輸連接只能有兩個端點添怔,只能進行點對點的數(shù)據(jù)傳輸环戈,不支持多播和廣播傳輸方式。
- 面向字節(jié)流
TCP不像UDP一樣那樣一個個報文獨立地傳輸澎灸,而是在不保留報文邊界的情況下以字節(jié)流方式進行傳輸院塞。
-
可靠傳輸
對于可靠傳輸,判斷丟包性昭,誤碼靠的是TCP的段編號以及確認號拦止。TCP為了保證報文傳輸?shù)目煽浚徒o每個包一個序號糜颠,同時序號也保證了傳送到接收端實體的包的按序接收汹族。然后接收端實體對已成功收到的字節(jié)發(fā)回一個相應的確認(ACK);如果發(fā)送端實體在合理的往返時延(RTT)內(nèi)未收到確認其兴,那么對應的數(shù)據(jù)(假設(shè)丟失了)將會被重傳顶瞒。
提供擁塞控制
當網(wǎng)絡出現(xiàn)擁塞的時候,TCP能夠減小向網(wǎng)絡注入數(shù)據(jù)的速率和數(shù)量元旬,緩解擁塞
- TCP提供全雙工通信
TCP允許通信雙方的應用程序在任何時候都能發(fā)送數(shù)據(jù)榴徐,因為TCP連接的兩端都設(shè)有緩存,用來臨時存放雙向通信的數(shù)據(jù)匀归。當然坑资,TCP可以立即發(fā)送一個數(shù)據(jù)段,也可以緩存一段時間以便一次發(fā)送更多的數(shù)據(jù)段(最大的數(shù)據(jù)段大小取決于MSS)
四穆端、TCP和UDP的比較
1. 對比
UDP | TCP | |
---|---|---|
是否連接 | 無連接 | 面向連接 |
是否可靠 | 不可靠傳輸袱贮,不使用流量控制和擁塞控制 | 可靠傳輸,使用流量控制和擁塞控制 |
連接對象個數(shù) | 支持一對一体啰,一對多攒巍,多對一和多對多交互通信 | 只能是一對一通信 |
傳輸方式 | 面向報文 | 面向字節(jié)流 |
首部開銷 | 首部開銷小,僅8字節(jié) | 首部最小20字節(jié)荒勇,最大60字節(jié) |
適用場景 | 適用于實時應用(IP電話柒莉、視頻會議、直播等) | 適用于要求可靠傳輸?shù)膽谜硖耄缥募鬏?/td> |
2. 總結(jié)
- TCP向上層提供面向連接的可靠服務 常柄,UDP向上層提供無連接不可靠服務鲤氢。
- 雖然 UDP 并沒有 TCP 傳輸來的準確搀擂,但是也能在很多實時性要求高的地方有所作為
- 對數(shù)據(jù)準確性要求高,速度可以相對較慢的卷玉,可以選用TCP