成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

UDP協(xié)議-看這篇就夠了

網絡 網絡管理
每一個程序員應該都知道TCP,UDP協(xié)議。UDP是用戶數據報文協(xié)議,屬于OSI模型中的傳輸層。它是一種無連接的協(xié)議,也就說上一報文和下一報文在協(xié)議層沒有任何聯(lián)系,同時提供了簡單的不可靠的傳輸服務。

每一個程序員應該都知道TCP,UDP協(xié)議。UDP是用戶數據報文協(xié)議,屬于OSI模型中的傳輸層。它是一種無連接的協(xié)議,也就說上一報文和下一報文在協(xié)議層沒有任何聯(lián)系,同時提供了簡單的不可靠的傳輸服務。

[[273925]]

也就是說UDP是不可靠的,如果要想讓數據可靠,就需要在業(yè)務層做糾錯和檢錯功能。比如:TFTP。

那可能就會有同學問了,既然是不可靠的,為什么不直接使用IP協(xié)議呢?還要這么大費周章增加一種協(xié)議UDP呢?

其實其中一個最重要的原因就是IP協(xié)議中沒有端口(port)的概念,它只是規(guī)定了兩臺主機之間的通信,并沒有解決不同主機上應用程序之間的通信。如果一個主機上的多個應用程序需要通信,直接用IP協(xié)議就無法數據區(qū)分數據到底哪個應用程序了。 

UDP協(xié)議-看這篇就夠了

可以理解為一個端口就是一個通信通道,當然UDP在IP協(xié)議的基礎上增加了一些功能,所以我們來總結下:

  1. UDP無連接,沒有連接。所以它的發(fā)送和接受的開銷就會小很多。
  2. UDP不保證數據可靠交付,只是盡最大可能。所以不需要維護復雜的連接關系。
  3. UDP是面向報文的,添加在應用層下來數據頭部,直接塞給IP層。
  4. UDP沒有擁塞控制
  5. UDP至支持多播。
  6. UDP頭部小,說明傳輸更多的數據內容

下圖展示是UDP和上下層的關系:

UDP協(xié)議-看這篇就夠了

UDP的首部到底是怎樣的呢?

先看下圖:

UDP協(xié)議-看這篇就夠了

從圖中可以看出,UDP的首部由四部分組成:

  • 各16bit的來源端口和目的端口用來標記發(fā)送和接受的應用進程。因為UDP不需要應答,所以來源端口是可選的,如果來源端口不用,那么置為零。當運輸層從IP層收到UDP數據報時,就是根據首部中的目的端口,把UDP數據報通過相應的端口,上交最后的終點--應用程序。
  • 如果接收方UDP發(fā)現收到的報文中的目的端口號不正確,就會丟棄改報文,并由網際控制協(xié)議ICMP發(fā)送“端口不可達”差錯報文給發(fā)送方。ICMP應用Traceroute,就是讓發(fā)送的UDP用戶數據報故意使用一個非法的UDP端口,結果ICMP返回“端口不可達”差錯報文,因而達到了測試的目的。
UDP協(xié)議-看這篇就夠了

在目的端口后面是長度固定的以字節(jié)為單位的報文長度域,用來指定UDP數據報包括數據部分的長度,長度最小值為8byte。

首部剩下地16bit是用來對首部和數據部分一起做校驗和(Checksum)的,這部分是可選的,但在實際應用中一般都使用這一功能。

UDP和TCP的校驗和都覆蓋到了他們的首部和數據,而IP首部的校驗和只覆蓋了IP首部。

UDP和socket怎樣配合使用

隨著我們進入傳輸層,我們也可以調用操作系統(tǒng)中的API,來構建socket。Socket是操作系統(tǒng)提供的一個編程接口,它用來代表某個網絡通信。應用程序通過socket來調用系統(tǒng)內核中處理網絡協(xié)議的模塊,而這些內核模塊會負責具體的網絡協(xié)議的實施。

這樣,我們可以讓內核來接收網絡協(xié)議的細節(jié),而我們只需要提供所要傳輸的內容就可以了,內核會幫我們控制格式,并進一步向底層封裝。因此,在實際應用中,我們并不需要知道具體怎么構成一個UDP包,而只需要提供相關信息(比如IP地址,比如端口號,比如所要傳輸的信息),操作系統(tǒng)內核會在傳輸之前會根據我們提供的相關信息構成一個合格的UDP包(以及下層的包和幀)。看下圖吧。

UDP協(xié)議-看這篇就夠了

UDP使用場景

需要資源少,在網絡情況比較好的內網,或者對于丟包不敏感的應用。如DHCP協(xié)議就是基于UDP的。一般的獲取IP地址都是內網請求,而且一次獲取不到IP又沒事。又比如基于UDP的RTP,TFTP,丟一幀數據問題也不大。再比如一些設備發(fā)現協(xié)議等等。

不需要一對一溝通,建立連接,而是可以廣播的應用。DHCP就是一種廣播的形式。VXLAN也是需要用到組播,也是基于UDP協(xié)議的。

需要處理速度快,時延低,可以容忍少數丟包,但是要求即便網絡擁塞,也毫不退縮,一往無前的時候。

QUIC是Google提出的一種基于UDP改進的通信協(xié)議,其目的是降低網絡通信的延遲,提供更好的用戶互動體驗。

結語

UDP沒有TCP那么復雜,但是網絡體系中不可缺少的協(xié)議。需要熟練的掌握該協(xié)議。

 

責任編輯:武曉燕 來源: 今日頭條
相關推薦

2021-09-30 07:59:06

zookeeper一致性算法CAP

2023-06-08 18:17:07

OSPF路由協(xié)議

2021-05-07 07:52:51

Java并發(fā)編程

2022-03-29 08:23:56

項目數據SIEM

2024-08-27 11:00:56

單例池緩存bean

2017-03-30 22:41:55

虛擬化操作系統(tǒng)軟件

2023-09-25 08:32:03

Redis數據結構

2023-11-07 07:46:02

GatewayKubernetes

2021-09-10 13:06:45

HDFS底層Hadoop

2023-10-04 00:32:01

數據結構Redis

2021-07-28 13:29:57

大數據PandasCSV

2021-10-21 06:52:17

ZooKeeper分布式配置

2023-12-07 09:07:58

2018-09-26 11:02:46

微服務架構組件

2021-04-11 08:30:40

VRAR虛擬現實技術

2022-08-18 20:45:30

HTTP協(xié)議數據

2021-11-10 07:47:48

Traefik邊緣網關

2021-12-13 10:43:45

HashMapJava集合容器

2023-11-22 07:54:33

Xargs命令Linux

2025-02-03 07:00:00

Java接口工具
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久久精 | 久久国产精品免费一区二区三区 | dy天堂| 在线看片福利 | 日韩中文一区 | 综合久久色 | 日韩av第一页 | 91精品导航 | 97精品一区二区 | 精品影院| 成人欧美一区二区三区黑人孕妇 | 国产96色在线 | 暖暖日本在线视频 | 午夜成人免费视频 | 岛国av免费在线观看 | 宅女噜噜66国产精品观看免费 | 国产精品日本一区二区在线播放 | 成人精品一区二区三区中文字幕 | 午夜免费电影 | 国产成人精品综合 | 免费在线观看黄色av | 久久精品超碰 | 99精品99| 精品国产三级 | 欧美精品二区三区 | 日韩视频在线免费观看 | 99成人| 一区二区三区四区不卡 | 午夜视频在线免费观看 | 97精品久久 | 久久精品日 | 黄a网| 黄色网址在线免费观看 | 国产福利精品一区 | 天天拍天天色 | 91色综合| 久久人人爽人人爽人人片av免费 | 操人视频在线观看 | 国产一区二区影院 | 91极品视频| 日韩成人免费视频 |