0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

TCP和UDP的原理以及區(qū)別

jf_78858299 ? 來源:程序員路人 ? 作者:程序員路人 ? 2023-05-18 17:14 ? 次閱讀

一、作用

首先,tcp和udp都是工作在傳輸層,用于程序之間傳輸數(shù)據(jù)的。數(shù)據(jù)一般包含:文件類型,視頻類型,jpg圖片等。

圖片

二、區(qū)別

TCP是基于連接的,而UDP是基于非連接的。

tcp傳輸數(shù)據(jù)穩(wěn)定可靠 ,適用于對(duì)網(wǎng)絡(luò)通訊質(zhì)量要求較高的場景,需要準(zhǔn)確無誤的傳輸給對(duì)方,比如,傳輸文件,發(fā)送郵件,瀏覽網(wǎng)頁等等

udp的優(yōu)點(diǎn)是速度快 ,但是可能產(chǎn)生丟包,所以適用于對(duì)實(shí)時(shí)性要求較高但是對(duì)少量丟包并沒有太大要求的場景。比如:域名查詢,語音通話,視頻直播等。udp還有一個(gè)非常重要的應(yīng)用場景就是隧道網(wǎng)絡(luò),比如:VXLAN

以人與人之間的通信為例:UDP協(xié)議就相當(dāng)于是寫信給對(duì)方,寄出去信件之后不能知道對(duì)方是否收到信件,信件內(nèi)容是否完整,也不能得到及時(shí)反饋,而TCP協(xié)議就像是打電話通信,在這一系列流程都能得到及時(shí)反饋,并能確保對(duì)方及時(shí)接收到。如下圖:

圖片

三、TCP通信的過程:

tcp是如何保證以上過程的?

分為三個(gè)步驟: 三次握手,傳輸確認(rèn),四次揮手 。三次握手是建立連接的過程。

四、三次握手:

當(dāng)客戶端向服務(wù)端發(fā)起連接時(shí),會(huì)先發(fā)一包連接請(qǐng)求數(shù)據(jù),過去詢問一下,能否與你建立連接?這包數(shù)據(jù)稱之為SYN包,如果對(duì)端同意連接,則回復(fù)一包SYN+ACK包,客戶端收到之后,發(fā)送一包ACK包,連接建立,因?yàn)檫@個(gè)過程中互相發(fā)送了三包數(shù)據(jù),所以稱之為三次握手。

圖片

為什么要三次握手而不是兩次握手?

這是為了防止,因?yàn)橐咽У恼?qǐng)求報(bào)文,突然又傳到服務(wù)器,引起錯(cuò)誤, 這是什么意思?

假設(shè)采用兩次握手建立連接,客戶端向服務(wù)端發(fā)送一個(gè)syn包請(qǐng)求建立連接,因?yàn)槟承┪粗脑?,并沒有到達(dá)服務(wù)器,在中間某個(gè)網(wǎng)絡(luò)節(jié)點(diǎn)產(chǎn)生了滯留,為了建立連接,客戶端會(huì)重發(fā)syn包,這次的數(shù)據(jù)包正常送達(dá),服務(wù)端發(fā)送syn+ack之后就建立起了連接。

但是第一包數(shù)據(jù)阻塞的網(wǎng)絡(luò)突然恢復(fù),第一包syn包又送達(dá)到服務(wù)端,這時(shí)服務(wù)端會(huì)認(rèn)為客戶端又發(fā)起了一個(gè)新的連接,從而在兩次握手之后進(jìn)入等待數(shù)據(jù)狀態(tài),服務(wù)端認(rèn)為是兩個(gè)連接,而客戶端認(rèn)為是一個(gè)連接,造成了狀態(tài)不一致,如果在三次握手的情況下,服務(wù)端收不到最后的ack包,自然不會(huì)認(rèn)為連接建立成功。

所以三次握手本質(zhì)上來說就是為了解決網(wǎng)絡(luò)信道不可靠的問題,為了在不可靠的信道上建立起可靠的連接,經(jīng)過三次握手之后,客戶端和服務(wù)端都進(jìn)入了數(shù)據(jù)傳輸狀態(tài)。

五、數(shù)據(jù)傳輸

數(shù)據(jù)傳輸:

一包數(shù)據(jù)可能會(huì)被拆成多包發(fā)送,如何處理丟包問題,這些數(shù)據(jù)包到達(dá)的先后順序不同,如何處理亂序問題?

針對(duì)這些問題,tcp協(xié)議為每一個(gè)連接建立了發(fā)送緩沖區(qū),從建立鏈接后的第一個(gè)字節(jié)的序列號(hào)為0,后面每個(gè)字節(jié)的序列號(hào)就會(huì)增加1,發(fā)送數(shù)據(jù)時(shí),從數(shù)據(jù)緩沖區(qū)取一部分?jǐn)?shù)據(jù)組成發(fā)送報(bào)文,在tcp協(xié)議頭中會(huì)附帶序列號(hào)和長度,接收端在收到數(shù)據(jù)后需要回復(fù)確認(rèn)報(bào)文,確認(rèn)報(bào)文中的ack等于接受序列號(hào)加長度,也就是下包數(shù)據(jù)發(fā)送的起始序列號(hào),這樣一問一答的發(fā)送方式,能夠使發(fā)送端確認(rèn)發(fā)送的數(shù)據(jù)已經(jīng)被對(duì)方收到,發(fā)送端也可以發(fā)送一次的連續(xù)的多包數(shù)據(jù),接受端只需要回復(fù)一次ack就可以了。如圖:

圖片

六、四次揮手:

圖片

處于連接狀態(tài)的客戶端和服務(wù)端,都可以發(fā)起關(guān)閉連接請(qǐng)求,此時(shí)需要四次揮手來進(jìn)行連接關(guān)閉。假設(shè)客戶端主動(dòng)發(fā)起連接關(guān)閉請(qǐng)求,他給服務(wù)端發(fā)起一包FIN包,標(biāo)識(shí)要關(guān)閉連接,自己進(jìn)入終止等待1裝填,服務(wù)端收到FIN包,發(fā)送一包ACK包,標(biāo)識(shí)自己進(jìn)入了關(guān)閉等待狀態(tài),客戶端進(jìn)入終止等待2狀態(tài),這是 第二次揮手 ,服務(wù)端此時(shí)還可以發(fā)送未發(fā)送的數(shù)據(jù),而客戶端還可以接受數(shù)據(jù),待服務(wù)端發(fā)送完數(shù)據(jù)之后,發(fā)送一包FIN包,最后進(jìn)入確認(rèn)狀態(tài),這是 第3次揮手 ,客戶端收到之后恢復(fù)ACK包,進(jìn)入超時(shí)等待狀態(tài),經(jīng)過超時(shí)時(shí)間后關(guān)閉連接,而服務(wù)端收到ACK包后,立即關(guān)閉連接,這是 第四次揮手

為什么客戶端要等待超時(shí)時(shí)間?這是為了保證對(duì)方已經(jīng)收到ACK包,因?yàn)榧僭O(shè)客戶端發(fā)送完最后一包ACK包后釋放了連接,一旦ACK包在網(wǎng)絡(luò)中丟失,服務(wù)端將一直停留在 最后確認(rèn)狀態(tài),如果等待一段時(shí)間,這時(shí)服務(wù)端會(huì)因?yàn)闆]有收到ack包重發(fā)FIN包,客戶端會(huì)響應(yīng) 這個(gè)FIN包進(jìn)行重發(fā)ack包,并刷新超時(shí)時(shí)間,這個(gè)機(jī)制跟第三次握手一樣。也是為了保證在不可靠的網(wǎng)絡(luò)鏈路中進(jìn)行可靠的連接斷開確認(rèn)。

七、UDP協(xié)議

udp:首先udp協(xié)議是非連接的,發(fā)送數(shù)據(jù)就是把簡單的數(shù)據(jù)包封裝一下,然后從網(wǎng)卡發(fā)出去就可以了,數(shù)據(jù)包之間并沒有狀態(tài)上的聯(lián)系,正因?yàn)閡dp這種簡單的處理方式,導(dǎo)致他的性能損耗非常少,對(duì)于cpu,內(nèi)存資源的占用也遠(yuǎn)小于tcp,但是對(duì)于網(wǎng)絡(luò)傳輸過程中產(chǎn)生的丟包,udp并不能保證,所以u(píng)dp在傳輸穩(wěn)定性上要弱于tcp。

所以, tcp和udp的主要區(qū)別: tcp傳輸數(shù)據(jù)穩(wěn)定可靠,適用于對(duì)網(wǎng)絡(luò)通訊質(zhì)量要求較高的場景,需要準(zhǔn)確無誤的傳輸給對(duì)方。比如,傳輸文件,發(fā)送郵件,瀏覽網(wǎng)頁等等,udp的優(yōu)點(diǎn)是速度快,但是可能產(chǎn)生丟包,所以適用于對(duì)實(shí)時(shí)性要求較高但是對(duì)少量丟包并沒有太大要求的場景。比如:域名查詢,語音通話,視頻直播等。

udp還有一個(gè)非常重要的應(yīng)用場景就是隧道網(wǎng)絡(luò),比如:VXLAN.

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • TCP
    TCP
    +關(guān)注

    關(guān)注

    8

    文章

    1399

    瀏覽量

    80588
  • UDP
    UDP
    +關(guān)注

    關(guān)注

    0

    文章

    330

    瀏覽量

    34548
  • 傳輸數(shù)據(jù)
    +關(guān)注

    關(guān)注

    1

    文章

    127

    瀏覽量

    16315
  • VxLAN
    +關(guān)注

    關(guān)注

    0

    文章

    24

    瀏覽量

    3993
收藏 0人收藏

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    簡單總結(jié)一下TCPUDP的原理以及區(qū)別

    以人與人之間的通信為例:UDP協(xié)議就相當(dāng)于是寫信給對(duì)方,寄出去信件之后不能知道對(duì)方是否收到信件,信件內(nèi)容是否完整,也不能得到及時(shí)反饋,而TCP協(xié)議就像是打電話通信,在這一系列流程都能得到及時(shí)反饋,并能確保對(duì)方及時(shí)接收到。
    的頭像 發(fā)表于 07-25 10:12 ?1803次閱讀
    簡單總結(jié)一下<b class='flag-5'>TCP</b>和<b class='flag-5'>UDP</b>的原理<b class='flag-5'>以及</b><b class='flag-5'>區(qū)別</b>

    TCP協(xié)議和UDP協(xié)議的區(qū)別有哪些

    計(jì)算機(jī)網(wǎng)絡(luò)簡答題1、TCP 協(xié)議和 UDP 協(xié)議的區(qū)別有哪些?(1)TCP 屬于面向連接的協(xié)議,UDP 屬于面向無連接的協(xié)議 ;(2)
    發(fā)表于 08-06 08:43

    TCPUDP區(qū)別分析

      傳輸層協(xié)議主要有TCPUDP。UDP提供無連接的通信,不能保證數(shù)據(jù)包被發(fā)送到目標(biāo)地址,典型的即時(shí)傳輸少量數(shù)據(jù)的應(yīng)用程序通常使用UDPTCP
    發(fā)表于 09-18 10:29 ?2次下載

    udptcp區(qū)別在哪里

    主要介紹udptcp區(qū)別在哪里,以及TCP協(xié)議和UDP協(xié)議為什么會(huì)共存?通常我們在說到網(wǎng)絡(luò)編
    發(fā)表于 12-08 14:08 ?8790次閱讀

    TCPUDP的原理以及區(qū)別

    最近重新認(rèn)知了一下TCPUDP的原理以及區(qū)別,做一個(gè)簡單的總結(jié)。
    發(fā)表于 08-08 14:34 ?1608次閱讀

    TCPUDP協(xié)議的區(qū)別

    最近重新認(rèn)知了一下TCPUDP的原理以及區(qū)別,做一個(gè)簡單的總結(jié)。
    發(fā)表于 11-03 10:25 ?1039次閱讀

    TCPUDP的作用及區(qū)別

      首先,tcpudp都是工作在傳輸層,用于程序之間傳輸數(shù)據(jù)的。數(shù)據(jù)一般包含:文件類型,視頻類型,jpg圖片等。
    的頭像 發(fā)表于 11-14 10:49 ?3783次閱讀

    UDPTCP區(qū)別

    在上一則文章中,對(duì) TCP 的**三次握手建立連接**和**四次揮手釋放連接**進(jìn)行了詳細(xì)地闡述,本節(jié)教程針對(duì)于 TCP 的其他內(nèi)容進(jìn)行講解,首先是同處于傳輸層協(xié)議的`UDP`協(xié)議,這兩者有什么
    的頭像 發(fā)表于 01-20 17:05 ?2046次閱讀
    <b class='flag-5'>UDP</b>和<b class='flag-5'>TCP</b>的<b class='flag-5'>區(qū)別</b>

    TCPUDP可以同時(shí)綁定相同的端口嗎?

    (InternetProtocol)的獨(dú)立的兩個(gè)協(xié)議,他們都工作在OSI模型中的網(wǎng)絡(luò)層。其中TCPUDP最大的區(qū)別就是面向連接和面向無連接。TCP當(dāng)需要傳輸?shù)臄?shù)據(jù)的可
    的頭像 發(fā)表于 02-06 11:16 ?2168次閱讀
    <b class='flag-5'>TCP</b>和<b class='flag-5'>UDP</b>可以同時(shí)綁定相同的端口嗎?

    udp是什么協(xié)議 TCPUDP區(qū)別

    TCP協(xié)議提供可靠的數(shù)據(jù)傳輸,UDP協(xié)議提供盡量高效的數(shù)據(jù)傳輸。TCP協(xié)議通過使用序列號(hào)、確認(rèn)應(yīng)答等機(jī)制,保證數(shù)據(jù)傳輸?shù)目煽啃?,?b class='flag-5'>UDP協(xié)議不提供可靠性保證,它只是簡單地把應(yīng)用程序傳給
    的頭像 發(fā)表于 06-26 17:47 ?1.2w次閱讀

    TCPUDP區(qū)別

    1.TCPUDP區(qū)別 TCP是面向連接的,UDP是面向無連接的; TCP只能一對(duì)一通信,
    的頭像 發(fā)表于 11-09 09:35 ?7050次閱讀
    <b class='flag-5'>TCP</b>和<b class='flag-5'>UDP</b>的<b class='flag-5'>區(qū)別</b>

    TCPUDP的基本區(qū)別

    TCPUDP基本區(qū)別 基于連接與無連接 TCP要求系統(tǒng)資源較多,UDP較少; UDP程序結(jié)構(gòu)較
    的頭像 發(fā)表于 11-13 15:27 ?5125次閱讀
    <b class='flag-5'>TCP</b>與<b class='flag-5'>UDP</b>的基本<b class='flag-5'>區(qū)別</b>

    UDPTCP的主要區(qū)別 UDP能否像TCP一樣實(shí)現(xiàn)可靠傳輸?

    UDPTCP的主要區(qū)別 UDP能否像TCP一樣實(shí)現(xiàn)可靠傳輸?TCP如何實(shí)現(xiàn)可靠性傳輸?
    的頭像 發(fā)表于 01-22 16:10 ?1137次閱讀

    udp是什么意思 簡述TCPUDP區(qū)別和聯(lián)系

    中的兩個(gè)基本協(xié)議。然而,TCPUDP之間存在一些重要的區(qū)別和聯(lián)系。 首先,TCP是一種面向連接的協(xié)議,而UDP是無連接的。這意味著通過
    的頭像 發(fā)表于 02-02 16:33 ?1811次閱讀

    tcpudp區(qū)別和聯(lián)系

    一、引言 在現(xiàn)代網(wǎng)絡(luò)通信中,數(shù)據(jù)傳輸是至關(guān)重要的。為了確保數(shù)據(jù)的可靠傳輸,網(wǎng)絡(luò)協(xié)議發(fā)揮著關(guān)鍵作用。傳輸控制協(xié)議(TCP)和用戶數(shù)據(jù)報(bào)協(xié)議(UDP)是兩種常用的網(wǎng)絡(luò)協(xié)議,它們在許多應(yīng)用場景中發(fā)
    的頭像 發(fā)表于 08-16 11:06 ?996次閱讀

    電子發(fā)燒友

    中國電子工程師最喜歡的網(wǎng)站

    • 2931785位工程師會(huì)員交流學(xué)習(xí)
    • 獲取您個(gè)性化的科技前沿技術(shù)信息
    • 參加活動(dòng)獲取豐厚的禮品