您的位置:首页 > 理论基础 > 计算机网络

tcp/ip协议概述(2)----udp

2020-01-15 12:05 1241 查看

udp是用户数据报文协议,属于osi模型中的传输层。它是一种无连接的协议,也就是说上一个报文和下一个报文在协议层没有任何联系,同时提供了简单的不可靠的传输服务。也就是说udp是不可靠的,如果要想让数据可靠,就需要在业务层做纠错和检错功能。比如:tftp。

为什么不直接使用ip协议呢?还要重新新增协议udp?

一个重要原因是ip协议中没有端口(port)的概念,它只是规定了两台之间的通信,并没有解决不同主机还是那个应用程序之间的通信。如果一个主机上的多个应用程序需要通信。直接用ip协议就无法区分数据到底是那个应用程序的。

可以理解为一个端口就是一个通信通道,当然udp在ip协议的基础上增加了一些功能,所以我们来总结下:

1.udp无连接,没有连接。所以它的发送和接受的开销就会小很多。

2.udp不保证数据可靠交付,只是尽量最大可能。所以不需要维护复杂的连接关系。

3.udp是面向报文的,添加在应用层下来数据头部,直接塞给ip层

4.udp没有用塞控制

5.udp只支持多播

6.udp头部小,说明传输更多的数据内容

下面是udp在osi中与上下层的关系

udp的首部格式:

从图中可以看出,UDP的首部由四部分组成:

  • 各16bit的来源端口和目的端口用来标记发送和接受的应用进程。因为UDP不需要应答,所以来源端口是可选的,如果来源端口不用,那么置为零。当运输层从IP层收到UDP数据报时,就是根据首部中的目的端口,把UDP数据报通过相应的端口,上交最后的终点--应用程序。
  • 如果接收方UDP发现收到的报文中的目的端口号不正确,就会丢弃改报文,并由网际控制协议ICMP发送“端口不可达”差错报文给发送方。ICMP应用Traceroute,就是让发送的UDP用户数据报故意使用一个非法的UDP端口,结果ICMP返回“端口不可达”差错报文,因而达到了测试的目的。

  • 在目的端口后面是长度固定的以字节为单位的报文长度域,用来指定UDP数据报包括数据部分的长度,长度最小值为8byte。
  • 首部剩下地16bit是用来对首部和数据部分一起做校验和(Checksum)的,这部分是可选的,但在实际应用中一般都使用这一功能。
  • UDP和TCP的校验和都覆盖到了他们的首部和数据,而IP首部的校验和只覆盖了IP首部。

UDP和socket怎样配合使用

随着我们进入传输层,我们也可以调用操作系统中的API,来构建socket。Socket是操作系统提供的一个编程接口,它用来代表某个网络通信。应用程序通过socket来调用系统内核中处理网络协议的模块,而这些内核模块会负责具体的网络协议的实施

这样,我们可以让内核来接收网络协议的细节,而我们只需要提供所要传输的内容就可以了,内核会帮我们控制格式,并进一步向底层封装。因此,在实际应用中,我们并不需要知道具体怎么构成一个UDP包,而只需要提供相关信息(比如IP地址,比如端口号,比如所要传输的信息),操作系统内核会在传输之前会根据我们提供的相关信息构成一个合格的UDP包(以及下层的包和帧)。看下图

UDP使用场景

  1. 需要资源少,在网络情况比较好的内网,或者对于丢包不敏感的应用。如DHCP协议就是基于UDP的。一般的获取IP地址都是内网请求,而且一次获取不到IP又没事。又比如基于UDP的RTP,TFTP,丢一帧数据问题也不大。再比如一些设备发现协议等等。
  2. 不需要一对一沟通,建立连接,而是可以广播的应用。DHCP就是一种广播的形式。VXLAN也是需要用到组播,也是基于UDP协议的。
  3. 需要处理速度快,时延低,可以容忍少数丢包,但是要求即便网络拥塞,也毫不退缩,一往无前的时候。
  4. QUIC是Google提出的一种基于UDP改进的通信协议,其目的是降低网络通信的延迟,提供更好的用户互动体验。
  • 点赞
  • 收藏
  • 分享
  • 文章举报
小志1989 发布了38 篇原创文章 · 获赞 3 · 访问量 869 私信 关注
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: