在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

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

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

Android編程精選 ? 來源:CSDN ? 作者:五顏六色的黑 ? 2022-07-25 10:12 ? 次閱讀

一、作用

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

poYBAGLd_MiAJPgsAAFCZgmLtrU009.jpg

二、區(qū)別

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

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

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

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

poYBAGLd_P-ATjQKAAFAkh2oOeI988.jpg

三、TCP通信的過程:

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

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

四、三次握手:

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

poYBAGLd_QWAXCy6AAEtewBS9-M918.jpg

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

這是為了防止,因為已失效的請求報文,突然又傳到服務器,引起錯誤, 這是什么意思?

假設(shè)采用兩次握手建立連接,客戶端向服務端發(fā)送一個syn包請求建立連接,因為某些未知的原因,并沒有到達服務器,在中間某個網(wǎng)絡節(jié)點產(chǎn)生了滯留,為了建立連接,客戶端會重發(fā)syn包,這次的數(shù)據(jù)包正常送達,服務端發(fā)送syn+ack之后就建立起了連接。

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

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

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

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

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

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

pYYBAGLd_QyAJJNAAAGZvDVjVls862.jpg

六、四次揮手:

poYBAGLd_RKAKVrMAAF6FuHHUQQ788.jpg

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

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

七、UDP協(xié)議

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

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

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

pYYBAGLd_SmABe_hAAEvIAvhPTE500.jpg




審核編輯:劉清

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

    關(guān)注

    9

    文章

    1931

    瀏覽量

    64726
  • TCP
    TCP
    +關(guān)注

    關(guān)注

    8

    文章

    1375

    瀏覽量

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

    關(guān)注

    0

    文章

    327

    瀏覽量

    34007
  • TCP通信
    +關(guān)注

    關(guān)注

    0

    文章

    146

    瀏覽量

    4259

原文標題:圖文并茂,講解TCP和UDP協(xié)議的原理以及區(qū)別

文章出處:【微信號:AndroidPush,微信公眾號:Android編程精選】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

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

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

    TCPUDP區(qū)別分析

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

    udptcp區(qū)別在哪里

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

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

    最近重新認知了一下TCPUDP的原理以及區(qū)別,做簡單
    發(fā)表于 08-08 14:34 ?1501次閱讀

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

    最近重新認知了一下TCPUDP的原理以及區(qū)別,做簡單
    發(fā)表于 11-03 10:25 ?890次閱讀

    UDPTCP區(qū)別

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

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

    TCP是基于連接的,而UDP是基于非連接的。 **tcp傳輸數(shù)據(jù)穩(wěn)定可靠** ,適用于對網(wǎng)絡通訊質(zhì)量要求較高的場景,需要準確無誤的傳輸給對方,比如,傳輸文件,發(fā)送郵件,瀏覽網(wǎng)頁等等
    的頭像 發(fā)表于 05-18 17:14 ?995次閱讀
    <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é)議(

    網(wǎng)絡編程有三個要素,分別是IP地址、端口號和通信協(xié)議,那本文主要講述的是TCPUDP這兩種通信協(xié)議,以及編程的實現(xiàn)。 首先,我們需要了解一下IP地址、端口號、通信協(xié)議的相關(guān)知識
    的頭像 發(fā)表于 05-18 17:17 ?669次閱讀
    <b class='flag-5'>一</b>文搞明白<b class='flag-5'>TCP</b>協(xié)議與<b class='flag-5'>UDP</b>協(xié)議(<b class='flag-5'>下</b>)

    UDP定比TCP更快嗎?什么情況UDP會更慢?

    當談到網(wǎng)絡傳輸時,大多數(shù)人可能認為TCP是最好的選擇。因為TCP種可靠的協(xié)議,它可以確保數(shù)據(jù)的可靠性和完整性。但是,當考慮到UDP時,
    的頭像 發(fā)表于 04-03 09:38 ?1628次閱讀
    <b class='flag-5'>UDP</b><b class='flag-5'>一</b>定比<b class='flag-5'>TCP</b>更快嗎?什么情況<b class='flag-5'>下</b>用<b class='flag-5'>UDP</b>會更慢?

    UDP能否像TCP樣實現(xiàn)可靠傳輸?

    連接的協(xié)議,基于字節(jié)流的傳輸方式。它通過確認和重傳等機制來保證數(shù)據(jù)的完整性和順序性,實現(xiàn)數(shù)據(jù)包的可靠傳輸。UDPTCP的主要區(qū)別但在某些運用場景,使用
    的頭像 發(fā)表于 06-08 14:50 ?945次閱讀
    <b class='flag-5'>UDP</b>能否像<b class='flag-5'>TCP</b><b class='flag-5'>一</b>樣實現(xiàn)可靠傳輸?

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

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

    TCPUDP區(qū)別

    1.TCPUDP區(qū)別 TCP是面向連接的,UDP是面向無連接的; TCP只能
    的頭像 發(fā)表于 11-09 09:35 ?6162次閱讀
    <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 ?4667次閱讀
    <b class='flag-5'>TCP</b>與<b class='flag-5'>UDP</b>的基本<b class='flag-5'>區(qū)別</b>

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

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

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

    中的兩個基本協(xié)議。然而,TCPUDP之間存在些重要的區(qū)別和聯(lián)系。 首先,TCP種面向連接
    的頭像 發(fā)表于 02-02 16:33 ?1367次閱讀
    主站蜘蛛池模板: 色视频网址| 人成网站在线观看| 日本不卡一区二区三区视频| 免费在线亚洲| 都市禁忌猎艳风流美妇| 亚洲三级免费观看| 五月天精品在线| 日韩精品午夜| 清纯唯美亚洲综合一区| 手机看片久久| 国产免费小视频| h网站国产| 最近2018中文字幕免费看手机| 五月婷婷狠狠| 欧美一级在线观看| 国产稀缺精品盗摄盗拍| 天天做天天爱夜夜爽| www.xxx.国产| 天天狠天天插| 放荡的俄罗斯美女bd| 一级a级国产不卡毛片| 在线日韩一区| 日本黄色录像视频| 成人欧美一区二区三区的电影| 神马国产| 一区二区在线观看高清| 亚洲男人的天堂成人| 模特精品视频一区| 97人人在线| 国产精品免费看久久久| 日本视频一区二区| 色在线视频网站| 韩国一级网站| 日日干狠狠干| 一区二区中文字幕在线观看| 性videofree极品另类| 亚洲乱码中文字幕综合| 日本xxxx色视频在线观看免 | 黄色网页在线播放| 亚洲国产日韩欧美在线as乱码| 男女艹逼软件|