基于UDP协议的UDT格式介绍

网络 网络管理
文章中,我们对UDT以及UDP协议的有关内容进行了详述。那么大家一起来看看UDT的结构吧。下面来浏览文章吧。

UDT,类似于UDP协议。那么它的中文翻译则是基于UDP的传输协议。在理解上面我们如何进行区分和理解呢?下面我们就来对这两个协议进行一下说明。首先,UDT是双工的,每个UDT实体有两个部分:发送和接收。发送者根据流量控制和速率控制来发送(和重传)应用程序数据。接收者接收数据包和控制包,并根据接收到的包发送控制包。发送和接收程序共享同一个UDP协议的端口来发送和接收。

接收者也负责触发和处理所有的控制事件,包括拥塞控制和可靠性控制和他们的相对机制,例如RTT估计、带宽估计、应答和重传。

UDT总是试着将应用层数据打包成固定的大小,除非数据不够这么大。和TCP相似的是,这个固定的包大小叫做MSS(***包大小)。由于期望UDT用来传输大块数据流,我们假定只有很小的一部分不规则的大小的包在UDT session中。MSS可以通过应用程序来安装,MTU是其***值(包括所有包头)。

UDT拥塞控制算法将速率控制和窗口(流量控制)合并起来,前者调整包的发送周期,后者限制***的位被应答的包。在速率控制中使用的参数通过带宽估计技术来更新,它继承来自基于接收的包方法。同时,速率控制周期是估计RTT的常量,流控制参数依赖于对方的数据到达速度,另外接收端释放的缓冲区的大小。

包结构

UDT有两种包:数据包和控制包。他们通过包头的***位来区分(标志位)。如果是0,表示是数据包,1表示是控制包。

数据包

数据包结构如下显示: 

数据包结构

包序号是UDT数据包头中唯一的内容。它是一个无符号整数,使用标志位后的31位,UDT使用包基础的需要,例如,每个非重传的包都增加序号1。序号在到达***值2^31-1的时候覆盖。紧跟在这些数据后面的是应用程序数据。

控制包

控制包结构如下:

控制包结构

有6种类型的控制包在UDT中,bit1-3表示这些信息。前32位在包头中必须存在。控制信息字段包括0(例如,它不存在)或者多个32位无符号整数,这由包类型决定。

UDT使用应答子序号的方法。每个ACK/ACK2包有一个无符号的16位序号,它独立于数据包需要。它使用位16-31。应答需要从0到(2^16-1)。位16-31在其他控制包中没有定义。

类型
说明
控制信息
000
协议连接握手
132 UDT版本
232内部顺序号
332 MSS(字节)
432***流量窗口大小(字节)
 
 
001
保活
没有
010
应答,位16-31是应答序号
132位包序号,先前接收到的包序号
232位,RTT(微秒)
332位,RTT 变量或者RTTVar (微秒)
432位,流量窗口大小(包的数量)
532位,连接容量估计(每秒包的数量)
011
Negative应答(NAK
丢失信息的32位整数数组,见3.9
100
保留
这种类型的控制信息保留作为拥塞警告使用,从接收到发送端。一个拥塞警告能被ECN或包延迟增加趋势的度量方法触发。
101
关闭
 
 
110
应答一个应答(ACK2
16-31位,应答序号。
111
4-15的解释
保留将来使用

 

注意,对于数据和控制包来说,可以从UDP协议头中得到实际的包大小。包大小信息能被用来得到有效的数据负载和NAK包中的控制信息字段大小。

定时器

UDT在接收端使用4个定时器来触发不同的周期事件,包括速率控制、应答、丢失报告(negative应答)和重传/连接维护。

UDT中的定时器使用系统时间作为源。UDT接收端主动查询系统时间来检查一个定时器是否过期。对于某个定时器T来说,其拥有周期TP,将定变量t用来记录最近T被设置或复位的时间。如果T在系统时间t0(t= t0)被复位,那么任何t1(t1-t>=TP)是T过期的条件。

四个定时器是:RC定时器、ACK定时器、NAK定时器、EXP定时器。他们的周期分别是:RCTP、ATP、NTP、ETP。

RC定时器用来触发周期性的速率控制。ACK定时器用来触发周期性的有选择的应答(应答包)。RCTP和ATP是常量值,值为:RCTP=ATP=0.01秒。

NAK被用来触发negative应答(NAK包)。重传定时器被用来触发一个数据包的重传和维护连接状态。他们周期依赖于对于RTT的估计。ETP值也依赖于连续EXP时间溢出的次数。推荐的RTT初始值是0.1秒,而NTP和ETP的初始值是:NTP=3*RTT,ETP=3*RTT+ATP。

在每次bounded UDP协议接收操作(如果收到一个UDP协议包,一些额外的必须的数据处理时间)时查询系统时间来检查四个定时器是否已经过期。推荐的周期粒度是微秒。UDP接收时间溢出值是实现的一个选择,这依赖于循环查询的负担和事件周期精确度之间的权衡。

速率控制事件更新包发送周期,UDT发送端使用STP来安排数据包的发送。假定一个在时间t0被发送,那么下一次包发送时间是(t0+ STP)。换句话说,如果前面的包发送花费了t’时间,发送端将等待(STP-t’)来发送下一个数据包(如果STP-t’ <0,就不需要等待了)。这个等待间隔需要一个高精确度的实现,推荐使用CPU时钟周期粒度。

责任编辑:佟健 来源: IT168
相关推荐

2010-07-12 15:40:24

2021-12-14 11:01:44

TCPUDP网络协议

2010-07-07 11:02:26

TCP UDP协议服务

2010-06-10 12:42:38

UDP协议

2010-07-06 15:16:34

UDP协议

2013-08-01 10:01:02

网络协议TCP协议UDP协议

2014-06-13 13:47:31

UDP

2010-06-28 15:45:07

UDP协议

2010-07-08 12:42:34

UDP协议

2020-01-03 07:57:39

UDPTCP网络协议

2010-07-12 21:14:09

UDP协议

2010-07-05 16:17:18

UDP协议

2010-07-09 09:29:00

UDP协议

2010-07-01 16:55:03

UDP协议

2010-07-07 11:17:01

UDP协议应用

2014-09-12 18:18:02

tcpudtUDP

2010-07-12 14:41:35

UDP协议

2010-07-06 15:28:57

UDP协议基础

2010-07-08 12:58:03

UDP协议

2010-07-09 11:12:09

UDP协议
点赞
收藏

51CTO技术栈公众号