UDP
一、 UDP协议的简介
UDP协议用户数据包协议,是一种无连接的传输层协议,提供简单不可靠的信息传送服务。在网络中它与TCP协议一样用于处理UDP数据包。UDP不提供数据包分组、组装、不能对数据包进行排序,也就是说,当报文发送之后,是无法得知其是否安全完整到达的。UDP 用来支持那些需要在计算机之间传输数据的网络应用。包括网络视频会议系统在内的众多的客户/服务器模式的网络应用都需要使用UDP 协议。
二、UDP协议报头
UDP报头由4个域组成,其中每个域各占用2个字节:
UDP源端口号
目标端口号
数据报长度
校验值
数据发送一方(可以是客户端或服务器端)将UDP数据报通过源端口发送出去,而数据接收一方则通过目标端口接收数据。
数据报的长度是指包括报头和数据部分在内的总字节数。从理论上说,包含报头在内的数据报的最大长度为65535字节。不过,一些实际应用往往会限制数据报的大小,有时会降低到8192字节。
UDP协议使用报头中的校验值来保证数据的安全。校验值首先在
数据发送方通过特殊的算法计算得出,在传递到接收方之后,还需要再重新计算。如果某个数据报在传输过程中被第三方篡改或者由于线路噪音等原因受到损坏,发送和接收方的校验计算值将不会相符,由此UDP协议可以检测是否出错。这与TCP协议是不同的,后者要求必须具有校验值。
虽然UDP提供有错误检测,但检测到错误时,UDP不做错误校正,只是简单地把损坏的消息段扔掉,或者给应用程序提供警告信息。
三、用户数据报头格式
域:源端口是可选域,当其有意义时,它指的是发送进程的端口,这也就假定了在没有其它信息的情况下,返回信息应该向什么地方发送。如果不使用它,则在此域中填0。目的端口在有特定的目的网络地址时有意义。长度指的是此用户数据报长度的八进制表示。(这表明最小的数据报长度是8。)校验码有16位,是对IP头,UDP头和数据中信息包头的数位取反之和再取反得到的。
报头从概念上说是在UDP头信息之前的,它包括有源地址,目的地地址,所使用的协议和UDP长度。这些信息使信息不能被错误地接收。这个校验过程与TCP中使用的过程一致。
用户接口:用户接口应该允许创建新的接收端口,在接收端口的接收操作有:应该返回一个八进制数说明源端口和源地址,允许数据报传送,指定数据,源和目标端口和目的地地址。
IP层接口:UDP模块必须能够决定源和目标的网络地址,而且必须能够从包头中得知所使用的协议。一个可能的接口方式是返回整个
数据报,包括接收操作返回的包头。这样的接口还应该允许UDP 向IP 传送完整的带包头的数据报用于传送。由IP 来确定一致性并计算校验码。
协议应用:此协议的最主要的用途是网际名称服务器和小文件传输协议。
协议号:在IP 中使用它时,它的协议号是17(八进制中是21)。
四、UDP 信息包
UDP 信息包由UDP 标题和数据组成。UDP 的标题结构如图所示,它由5个域组成:源端端口、目的地端口、用户数据包的长度和检查和。其中,前4个域组成UDP 标题,每个域由4个字节组成;检查和域占据2个字节,它用来检测传输过程中是否出现了错误;用户数据包的长度包括所有5个域的字节数。 32位
0 7| 8 15|16 23|24 31
源端端口
(Source Port )
检查和 (Checksum)
用户数据包的长度
(Length) 目的地端口 (Destination Port ) 数据
(Date )
……
五、UDP的伪首部
UDP校验和覆盖的内容超出了UDP数据报本身的范围。为了计算校验和,UDP把伪首部引入数据报中,在伪首部中有一个值为0的填充八位组用于保证整个数据报的长度为16比特的整数倍,这样才好计算校验和。填充八位组和伪首部并不随着UDP数据报一起传输,也不计算在数据报长度之内。为了计算校验和,要先把校验和字段置为0,然后对整个对象,包括伪首部、UDP的首部和用户数据报,计算一个16比特的二进制反码和。使用伪首部的目的是检验UDP数据报已到达正确的目的地。理解伪首部的关键在于认识到:正确的目的地包括了特定的主机和机器上特定的协议端口。UDP报文的首部仅仅指定了使用的协议端口号。因此为了确保数据报能够正确到达目的地,发送UDP数据报的机器在计算校验和时把目的机的IP地址和应有的数据都包括在内。在最终的接收端,UDP协议软件对校验和进行检验时要用到携带UDP报文的IP数据报首部中的lP地址。如果校验和正确,说明UDP数据报到达了正确主机的正确端口。
在UDP校验和的计算过程中用到的伪首部长度为12个八位组,其结构如下图所示。
0 8 16 31
源IP地址
目的IP地址
0协议UDP长度
伪首部的源IP地址字段和目的IP地址字段记录了发送UDP报文时使用的源IP地址和目的IP地址。协议字段指明了所使用的协议类型代码(UDP是17),而长度字段是UDP数据报的长度。接收方进行正确性验证的时候,必须要把这些字段的信息从IP报文的首部中抽取出来,以伪首部的格式进行装配,然后再重新计算校验和。六、UDP的封装
在交给IP层之前,UDP给用户要发送的数据加上一个首部。IP 层又给从UDP接收到的数据报加上一个首部。最后,网络接口层把数据报封装到一个帧里,再进行机器之间的传送。如图所示。帧的结构根据底层的网络技术来确定。通常网络帧结构包括一个附加的首部。
UDP 首部UDP 数据区
IP首部IP 数据区
帧首部帧的数据区
七、层次的划分及UDP校验和的计算
分层原则与UDP校验和的计算过程看来存在一定的冲突。UDP 校
验和覆盖了一个伪首部,而这个伪首部中包括了源IP地址和FI的IP地址。一般情况下,可以认为进行发送的用户必须知道目的IP地址,在发送数据时把目的IP地址告诉了UDP层,这样UDP层就可以直接得知目的IP地址,而不必到IP层寻找。但是,源IP地址要根据IP层对路由的选择而定,因为源IP地址会表示出数据报传输时所经过的网络接口。因此,如果不与IP层进行交互,UDP层是无法得知源IP地址的。假定UDP软件要求IP层提供源IP地址和目的IP地址,再用这些信启、去生成伪首部,计算校验和,丢弃伪首部,并将UDP数掘报交给IP层传输。一种可选的提高软件效率的方法是让UDP 层把UDP数据报封装到一个IP数据报中,从IP层获取源地址,把源地址和目的地址填到数据报首部中的相应字段中,再计算UDP校验和,最后把这个IP数据报交给IP层,而IP层只需要填充IP报文首部中的其余字段。
UDP和IP这样密切的交互操破坏了各层的功能独立性,明显是一种对严格的层次结构的折衷,完全是出于实际需要。之所以忽略违反分层结构的情况,是因为几乎不可能在不指定目的机的前提下识别目的应用程序,而且我们希望对UDP所使用的地址和IP所使用的地址进行有效的映射。
八、UDP的多路复用、多路分解和端口
协议各层的软件都要对相邻层的多个对象进行多路复用和多路分解操作。UDP软件接收多个应用程序送来的数据报,把它们送给IP 层进行传输,同时它接收从IP层送来的UDP数据报,并把它们送给