chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

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

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

TCP/UDP協(xié)議到底是怎么回事

jf_78858299 ? 來源:簡書 ? 作者:Martin_wjl ? 2023-05-18 17:10 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

TCP/IP五層網(wǎng)絡結(jié)構(gòu)模型

  • 物理層:物理層建立在物理通信介質(zhì)的基礎上,作為系統(tǒng)和通信介質(zhì)的接口,用來實現(xiàn)數(shù)據(jù)鏈路實體間透明的比特 (bit) 流傳輸。只有該層為真實物理通信,其它各層為虛擬通信
  • 數(shù)據(jù)鏈路層:在物理層提供比特流服務的基礎上,建立相鄰結(jié)點之間的數(shù)據(jù)鏈路,通過差錯控制提供數(shù)據(jù)幀(Frame)在信道上無差錯的傳輸,并進行各電路上的動作系列。數(shù)據(jù)的單位稱為幀(frame)
  • 網(wǎng)絡層:選擇合適的路由,使數(shù)據(jù)分組(packet)可以交付到目的主機
  • 傳輸層:負責主機中進程間的通信
  • 應用層:直接為用戶的應用程序提供服務

用圖說話:

圖片

傳輸層

我們知道傳輸層是在進程間傳輸報文,同時TCP協(xié)議、UDP協(xié)議是TCP/IP中最具有代表性的傳輸層協(xié)議。下面就總結(jié)一下兩個協(xié)議的異同以及傳輸層的工作原理。

TCP與UDP區(qū)分:

TCP協(xié)議:面向連接、可靠的流協(xié)議。連接是指兩個應用程序為了相互傳遞信息而專有的、虛擬的通信線路,也叫做虛擬電路。流是指不間斷的數(shù)據(jù)結(jié)構(gòu),類似于管道中的水流??煽啃灾窽CP協(xié)議提供可靠性傳輸,實行“順序控制”或“重發(fā)控制”機制。此外還具有“流量控制”、“擁塞控制”提供網(wǎng)絡利用率等眾多功能。

UDP協(xié)議:不具有可靠性的數(shù)據(jù)報協(xié)議。只確保發(fā)送消息,其他處理都由上層應用來完成。

哇!TCP這么多特點,是不是一定比UDP厲害呢?其實不然,他們各有自己的應用場景。

TCP應用場景:效率要求相對低,但對準確性要求相對高的場景。因為傳輸中需要對數(shù)據(jù)確認、重發(fā)、排序等操作,相比之下效率沒有UDP高。舉幾個例子:文件傳輸(準確高要求高、但是速度可以相對慢)、接受郵件、遠程登錄。

UDP應用場景:效率要求相對高,對準確性要求相對低的場景。舉幾個例子:QQ聊天、在線視頻、網(wǎng)絡語音電話(即時通訊,速度要求高,但是出現(xiàn)偶爾斷續(xù)不是太大問題,并且此處完全不可以使用重發(fā)機制)、廣播通信(廣播、多播)。

傳輸通信:

兩個協(xié)議是進程間通信,也就是說應用間的通信,那么如何在眾多程序中找到自己的目的應用呢?在傳輸層,使用端口號來識別同一臺計算機中進行通信的不同應用程序。

一般情況下可以根據(jù)“源IP地址”、“目標IP地址”、“源端口號”、“目標端口號”來進行識別一個通信,但是有些特殊情況,比如IP地址和端口號都一樣,只是使用的傳輸協(xié)議不一樣,怎么進行區(qū)分?數(shù)據(jù)到達IP層(網(wǎng)絡層)之后,會先檢查IP頭部的協(xié)議號,然后再傳給相應協(xié)議的模塊。

因此,TCP/IP或UDP/IP通信中通常使用5個信息來識別一個通信:“源IP地址”、“目標IP地址”、“源端口號”、“目標端口號”以及“協(xié)議號”。(知名端口號與傳輸層協(xié)議沒有關系,例如53端口在TCP、UDP中都用于DNS服務)

端口號如何確定:標準既定的端口號,0-1023為知名端口號,其他已正式注冊的端口號是1024-49151;動態(tài)分配端口號,操作系統(tǒng)來為應用程序分配互不沖突的端口號,下一個端口號是在前一個分配號上加1,動態(tài)分配端口號范圍49152-65535.

UDP詳解

UDP是User Datagram Protocol縮寫。UDP不提供復雜的控制機制,利用IP提供面向無連接的通信服務。并且它是將應用程序發(fā)來的數(shù)據(jù)在收到的那一刻,立即按照原樣發(fā)送到網(wǎng)絡上的一種機制。

UDP為何存在?有哪些優(yōu)點呢?

  • 無需建立連接(減少延遲)
  • 實現(xiàn)簡單:無需維護連接狀態(tài)
  • 頭部開銷小
  • 沒有擁塞控制:應用可以更好的控制發(fā)送時間和發(fā)送速率

UDP頭部:

圖片

UDP的頭部是由源端口號、目標端口號、包長和校驗和組成。checksum主要是用來檢測UDP段在傳輸中是否發(fā)生了錯誤。還有就是,校驗和計算中也需要計算UDP偽頭部,偽頭部包含IP頭部的一些字段。我們剛才介紹了識別一個通信需要5項信息,而UDP頭部只有端口號,余下的三項在IP頭部,所以引入了偽頭部的概念。(IPv6的IP頭部沒有校驗和字段)

圖片

目前有一些場景需要兼顧可靠性和高效性,那么如何在UDP上實現(xiàn)可靠數(shù)據(jù)傳輸呢?

TCP詳解

TCP通過校驗和、序列號、確認應答、重發(fā)控制、連接管理以及窗口控制等機制實現(xiàn)可靠性傳輸。

連接管理:

數(shù)據(jù)通信之前必須先做好連接工作,在TCP中連接的建立需要三次握手,同時在通信結(jié)束時會進行斷開連接的處理(四次揮手)。一個連接的建立與斷開,正常過程至少需要來回送7個包才能完成。

圖片

在TCP中,當發(fā)送端的數(shù)據(jù)到達主機時,接收端主機會返回一個已收到消息的通知,這個消息叫ACK(確認應答,Positive Acknowledgement)。如果沒有收到ACK,那么很可能出現(xiàn)了丟包或者返回的確認在途中丟失,此外,也可能是由于其他原因,ACK延遲到達。發(fā)送方?jīng)]有收到ACK的話就會進行重發(fā),但是針對延遲和ACK丟失的情況,會存在重復發(fā)送和接收。于是我們就引入了一種機制,來識別是否已經(jīng)接收數(shù)據(jù),又能識別是否已經(jīng)接收。

上述重復控制的功能可以通過序列號來實現(xiàn)。序列號是按照順序給發(fā)送數(shù)據(jù)的每一個字節(jié)都標上號碼的編號,接收端查詢接收數(shù)據(jù)TCP首部中的序列號和數(shù)據(jù)的長度,將自己下一步應該接收的 序號作為確認應答號返送回去。通過序列號和確認應答號,TCP實現(xiàn)可靠傳輸。

圖片

利用窗口控制提高速度

如果我們每發(fā)送一個段就進行一次確認,那么包的往返時間越長,網(wǎng)絡的吞吐量量就會越差,通信性能就會越低。

為了解決這個問題,TCP引入了窗口的概念。確認應答不再是以每個片段,而是以更大的單位(窗口大?。┻M行確認,轉(zhuǎn)發(fā)時間就被大幅度的縮短。至于窗口的大小是由接收端主機決定的,也方便進行流控制。

窗口控制與重發(fā)控制

允許發(fā)送方在收到ACK之前連續(xù)發(fā)送多個分組,針對段丟失的情況,我們來討論窗口控制。

針對以前的延遲ACK,使用窗口控制之后,可以收到確認應答之前繼續(xù)發(fā)送報文,這樣整體速度就大大提高。

針對確認應答未能返回的情況。沒有使用窗口控制的時候,沒有收到確認應答的數(shù)據(jù)都會被重發(fā),而使用了窗口控制,某些確認應答即便丟失也無需重發(fā)。可以根據(jù)自己的確認應答或者下一個確認應答來確認。

圖片

針對報文段丟失的情況。當一個報文丟失時,發(fā)送端會連續(xù)收到多個序號為1001的確認應答,來提醒發(fā)送端再次發(fā)送報文。對于發(fā)送端,如果連續(xù)三次收到同一個確認應答,將會對其對應的數(shù)據(jù)進行重發(fā)。

圖片

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

    關注

    8

    文章

    1402

    瀏覽量

    80976
  • UDP
    UDP
    +關注

    關注

    0

    文章

    330

    瀏覽量

    34625
  • 物理層
    +關注

    關注

    1

    文章

    155

    瀏覽量

    35044
  • bit
    bit
    +關注

    關注

    0

    文章

    48

    瀏覽量

    32440
  • 通信介質(zhì)

    關注

    0

    文章

    2

    瀏覽量

    5093
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

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

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

    TCPUDP協(xié)議簡析

    一、前言TCPUDP協(xié)議TCP/IP協(xié)議的核心。TCP (Transmission Cont
    發(fā)表于 12-15 08:13

    通訊協(xié)議TCPUDP協(xié)議使用方法

    通訊協(xié)議TCPUDP協(xié)議UDP會把數(shù)據(jù)一股腦兒地發(fā)送出去,并不會在意是否全部收到,適用于廣播類型多對多通訊類型,缺點是具有一定的丟包率
    發(fā)表于 01-21 14:53

    TCPUDP的區(qū)別分析

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

    (WiFi干貨)WiFi模塊的TCPUDP協(xié)議

    TCPUDP都是網(wǎng)絡通信協(xié)議,也就是通信時都要遵守的規(guī)則,雙方在同一規(guī)則下”交流”,才能理解或者為之服務.?一、TCP協(xié)議全稱:Trans
    的頭像 發(fā)表于 09-11 09:02 ?3.1w次閱讀

    tcpudp協(xié)議的異同

    。UDP 校驗和則是包含 UDP 首部和數(shù)據(jù)在內(nèi)的校驗結(jié)果。 TCP協(xié)議 TCP協(xié)議基于網(wǎng)絡層的
    的頭像 發(fā)表于 11-12 14:45 ?4443次閱讀
    <b class='flag-5'>tcp</b>和<b class='flag-5'>udp</b><b class='flag-5'>協(xié)議</b>的異同

    線性科技是怎么回事

    線性科技是怎么回事?
    發(fā)表于 04-21 14:47 ?3次下載
    線性科技是<b class='flag-5'>怎么回事</b>?

    TCP協(xié)議UDP協(xié)議的區(qū)別和相同點有哪些 一文看懂TCP協(xié)議UDP協(xié)議的優(yōu)缺點

    首先咱們弄清楚,TCP協(xié)議和UCP協(xié)議TCP/IP協(xié)議的聯(lián)系,很多人犯糊涂了,一直都是說TCP
    的頭像 發(fā)表于 05-26 14:35 ?1w次閱讀
    <b class='flag-5'>TCP</b><b class='flag-5'>協(xié)議</b>與<b class='flag-5'>UDP</b><b class='flag-5'>協(xié)議</b>的區(qū)別和相同點有哪些 一文看懂<b class='flag-5'>TCP</b><b class='flag-5'>協(xié)議</b>與<b class='flag-5'>UDP</b><b class='flag-5'>協(xié)議</b>的優(yōu)缺點

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

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

    TCP協(xié)議UDP協(xié)議的區(qū)別

    TCP/IP協(xié)議中有兩個具有代表性的傳輸層協(xié)議,分別是TCP協(xié)議UDP
    的頭像 發(fā)表于 03-21 10:39 ?1378次閱讀

    TCP協(xié)議UDP協(xié)議最核心的區(qū)別是什么?

    對于TCP協(xié)議UDP協(xié)議,大家應該都有所耳聞。TCP協(xié)議
    發(fā)表于 06-15 09:37 ?956次閱讀
    <b class='flag-5'>TCP</b><b class='flag-5'>協(xié)議</b>和<b class='flag-5'>UDP</b><b class='flag-5'>協(xié)議</b>最核心的區(qū)別是什么?

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

    TCP協(xié)議提供可靠的數(shù)據(jù)傳輸,UDP協(xié)議提供盡量高效的數(shù)據(jù)傳輸。TCP協(xié)議通過使用序列號、確認應
    的頭像 發(fā)表于 06-26 17:47 ?1.2w次閱讀

    CNN到底是怎么回事?

    它用TensorFlow.js加載了一個10層的預訓練模型,相當于在你的瀏覽器上跑一個CNN模型,只需要打開電腦,就能了解CNN究竟是怎么回事
    的頭像 發(fā)表于 06-28 14:47 ?4533次閱讀
    CNN<b class='flag-5'>到底是</b><b class='flag-5'>怎么回事</b>?

    TCP/IP協(xié)議進階課程:5、UDP協(xié)議

    電子發(fā)燒友網(wǎng)站提供《TCP/IP協(xié)議進階課程:5、UDP協(xié)議.pdf》資料免費下載
    發(fā)表于 07-31 11:48 ?0次下載
    <b class='flag-5'>TCP</b>/IP<b class='flag-5'>協(xié)議</b>進階課程:5、<b class='flag-5'>UDP</b><b class='flag-5'>協(xié)議</b>

    TCP協(xié)議UDP協(xié)議的區(qū)別

    。 UDP(用戶數(shù)據(jù)報協(xié)議) : 無連接 :UDP不建立連接,數(shù)據(jù)可以直接發(fā)送,不需要任何握手過程。 不可靠性 :UDP不保證數(shù)據(jù)的可靠傳輸,數(shù)據(jù)包可能會丟失,不會重傳。 2. 數(shù)據(jù)傳
    的頭像 發(fā)表于 01-22 09:44 ?775次閱讀