亚洲精品久久久久久久久久久,亚洲国产精品一区二区制服,亚洲精品午夜精品,国产成人精品综合在线观看,最近2019中文字幕一页二页

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

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

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

TCP和UDP的作用及區(qū)別

架構師技術聯(lián)盟 ? 來源:csdn ? 作者:五顏六色的黑 ? 2022-11-14 10:49 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群


	

一、作用

首先,tcp和udp都是工作在傳輸層,用于程序之間傳輸數(shù)據(jù)的。數(shù)據(jù)一般包含:文件類型,視頻類型,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é)議就像是打電話通信,在這一系列流程都能得到及時反饋,并能確保對方及時接收到。如下圖:

三、TCP通信的過程:

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

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

四、三次握手:

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

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

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

假設采用兩次握手建立連接,客戶端向服務端發(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就可以了。如圖:

六、四次揮手:

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

為什么客戶端要等待超時時間?這是為了保證對方已經(jīng)收到ACK包,因為假設客戶端發(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。

審核編輯:郭婷


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

    關注

    13

    文章

    10035

    瀏覽量

    90512
  • TCP
    TCP
    +關注

    關注

    8

    文章

    1417

    瀏覽量

    82834

原文標題:網(wǎng)絡協(xié)議:TCP和UDP什么區(qū)別?(附視頻)

文章出處:【微信號:架構師技術聯(lián)盟,微信公眾號:架構師技術聯(lián)盟】歡迎添加關注!文章轉(zhuǎn)載請注明出處。

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    第二十五章 W55MH32 TCP_Server_Multi_Socket示例

    、數(shù)據(jù)交互及連接關閉的完整過程。文章詳細介紹了 TCP?協(xié)議的概念、特點、與 UDP?的區(qū)別、應用場景、數(shù)據(jù)交互流程、ACK?機制、重傳機制和 Keepalive?機制,幫助讀者理解其在可靠數(shù)據(jù)傳輸中的實際應用價值。
    的頭像 發(fā)表于 07-24 16:10 ?544次閱讀
    第二十五章 W55MH32 <b class='flag-5'>TCP</b>_Server_Multi_Socket示例

    第二十四章 W55MH32TCP_Client_Multi_Socket示例

    及處理連接關閉的完整過程。文章詳細介紹了 TCP?協(xié)議的概念、特點、與 UDP?的區(qū)別、應用場景、數(shù)據(jù)交互流程、ACK?機制、重傳機制和 Keepalive?機制,幫助讀者理解其在可靠數(shù)據(jù)傳輸中的實際應用價值。
    的頭像 發(fā)表于 07-24 16:08 ?494次閱讀
    第二十四章 W55MH32<b class='flag-5'>TCP</b>_Client_Multi_Socket示例

    第三章 W55MH32 TCP Client示例

    本文介紹在 W55MH32?芯片上實現(xiàn) TCP?客戶端模式進行數(shù)據(jù)回環(huán)測試的方法。闡述 TCP?協(xié)議概念、特點、與 UDP?區(qū)別、應用場景及相關機制。展示實現(xiàn)過程,包括開啟 Keepa
    的頭像 發(fā)表于 07-24 09:06 ?633次閱讀
    第三章 W55MH32 <b class='flag-5'>TCP</b> Client示例

    通用型上位機,支持串口、UDP、TCP,可以在表格中自由編輯公式和數(shù)據(jù),可以組態(tài)

    、顯示、存儲和控制等功能。支持異步串口、UDP、TCP。支持同時創(chuàng)建多個接口,各接口間數(shù)據(jù)可以自由交換。支持十六進制數(shù)據(jù)、JSON格式的數(shù)據(jù)。本上位機軟件最大的特點是用戶可以在表格中像編輯Excel表
    發(fā)表于 07-17 14:58

    開源直接用!UDP-UART數(shù)據(jù)透傳來了

    今天就來分享一下UDP-UART透傳示例,源碼開放,可根據(jù)實際需求靈活應用。 一、UDP-UART透傳簡介 UDP-UART透傳是一種將UDP數(shù)據(jù)流直接傳輸?shù)経ART接口的通信方式。它
    的頭像 發(fā)表于 02-05 17:14 ?502次閱讀
    開源直接用!<b class='flag-5'>UDP</b>-UART數(shù)據(jù)透傳來了

    如何優(yōu)化TCP協(xié)議的性能

    優(yōu)化TCP協(xié)議的性能可以從多個方面入手,以下是一些關鍵的策略和方法: 一、調(diào)整TCP參數(shù) TCP窗口大小 : 重要性 :TCP窗口大小是衡量TCP
    的頭像 發(fā)表于 01-22 09:52 ?1329次閱讀

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

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

    Web端TCP/UDP測試工具!小白必學~

    Web端TCP/UDP測試工具,方便大家進行各種基于TCP和TDP的模擬測試。該測試工具不僅支持TCPUDP測試,還支持SSL,使用極為便
    的頭像 發(fā)表于 01-08 18:17 ?1853次閱讀
    Web端<b class='flag-5'>TCP</b>/<b class='flag-5'>UDP</b>測試工具!小白必學~

    TCP三次握手與UDP區(qū)別

    在計算機網(wǎng)絡中,數(shù)據(jù)傳輸?shù)目煽啃院托适莾蓚€關鍵因素。為了滿足不同的應用需求,設計者們開發(fā)了多種傳輸層協(xié)議。其中,TCP(傳輸控制協(xié)議)和UDP(用戶數(shù)據(jù)報協(xié)議)是最常用的兩種。它們在數(shù)據(jù)傳輸機制
    的頭像 發(fā)表于 01-03 17:35 ?1153次閱讀

    TCP三次握手協(xié)議的作用

    在計算機網(wǎng)絡中,數(shù)據(jù)的傳輸需要在發(fā)送方和接收方之間建立一個穩(wěn)定的連接,以確保數(shù)據(jù)的完整性和順序。TCP(傳輸控制協(xié)議)是一種面向連接的、可靠的、基于字節(jié)流的傳輸層通信協(xié)議,它通過三次握手協(xié)議來建立
    的頭像 發(fā)表于 01-03 17:15 ?1349次閱讀

    一文了解Android UDP通信

    協(xié)議。發(fā)送方的UDP對應用程序交下來的報文,在添加首部后就向下交付IP層。UDP對應用層交下來的報文,既不合并,也不拆分,而是保留這些報文的邊界。 首部開銷?。?UDP的首部開銷只有8個字節(jié),比
    發(fā)表于 12-30 10:56

    socket 和 UDP 協(xié)議的對比

    。 Socket 定義 Socket 是一個抽象層,它提供了一種方式,使得應用程序能夠發(fā)送和接收數(shù)據(jù)。在網(wǎng)絡編程中,Socket 允許程序創(chuàng)建一個通信端點,通過這個端點,程序可以與其他程序進行數(shù)據(jù)交換。Socket 可以基于不同的傳輸層協(xié)議,如 TCPUDP。 特點
    的頭像 發(fā)表于 11-12 14:28 ?1323次閱讀

    4G模組之UDP應用的最佳實踐!

    今天說的是4G模組之UDP應用,展示最佳實踐,送你參考。
    的頭像 發(fā)表于 11-08 09:24 ?1539次閱讀
    4G模組之<b class='flag-5'>UDP</b>應用的最佳實踐!

    奇妙的Air780E之UDP應用示例大賞!

    關于UDP是一種無連接的、不可靠的傳輸層協(xié)議,主要用于實現(xiàn)網(wǎng)絡中的快速通訊,我們今天將把Air780E的UDP應用分析透徹。
    的頭像 發(fā)表于 11-04 09:25 ?968次閱讀
    奇妙的Air780E之<b class='flag-5'>UDP</b>應用示例大賞!

    socket與WebSocket的區(qū)別與聯(lián)系

    ) : Socket是一種通信端點,它在網(wǎng)絡編程中用于實現(xiàn)不同主機之間的通信。Socket可以是TCP套接字或UDP套接字,分別對應于TCP(傳輸控制協(xié)議)和UDP(用戶數(shù)據(jù)報協(xié)議)。
    的頭像 發(fā)表于 11-04 09:19 ?1672次閱讀