NS2流量整形器

1、Destination
学习令牌桶数据整形器如何对流量调整传输速率

2、Background
由于网络传输的突发性,往往导致网络拥塞,而一些实时服务或者重要应用要求必须保证网路通信的质量,相应的出现QoS的探讨和研究。实现QoS的方法有 InteServ(综合服务),DiffServer(区分服务)和Traffic Shaper(流量整形)。流量整形就是调整传输数据的平均速度,让封包按照传输规定的速率进行传送,尽量避免流量因突发的特性(Burstiness)而造成网络拥塞的情况发生。

作为方法之一,流量整形使用队列来限制可能导致网络拥塞的突发流量。数据先被缓存,然后再以规定的速率发送到网络上,以确保数据流速符合该连接所承诺的流速。流量整形被应用在ATM、帧中继和其他类型的网络中。它有时也被称为计量(metering)、整形(shaping)和平滑 (smoothing)。

Traffic  shaper的工作原理可分为基于队列的算法和基于TCP滑动窗口策略两类。流量整形传统上位于网络边缘,尽管可以使用它们对内部局域网流量进行整形。而且业务流量整形工作于第七层,可以解决前面提到的多种服务共用同一端口的问题。业务流量整形可以进行基于业务分类(比如按协议、子网进行分类)的流量整 形,可以设定最小最大带宽,在带宽条件允许的时候,还允许突发传输。

流量整形(Traffic  shaper)也许是最有效的QoS实现方法,目前已经很多的厂家生成了流量整形相关的硬件设备和软件产品来保障网络通信的质量,使用该方法不需要对已有的网络进行大的变更,同时还可以利用该方法来实现网络流量的合理分配。

流量整形的方式主要采用两种基本的算法
(1)漏桶(Leaky Bucket)算法
漏桶算法(Leaky Bucket)是网络世界中流量整形(Traffic Shaping)或速率限制(Rate  Limiting)时经常使用的一种算法,它的主要目的是控制数据注入到网络的速率,平滑网络上的突发流量。漏桶算法提供了一种机制,通过它,突发流量可以被整形以便为网络提供一个稳定的流量。

漏桶可以看作是一个带有常量服务时间的单服务器队列,如果漏桶(包缓存)溢出,那么数据包会被丢弃。
漏桶算法的基本内容如下:
*  漏桶算法强制一个常量的输出速率而不管输入数据流的突发性。当输入空闲时,该算法不执行任何动作;
* 主机在每一个时间片向网络注入一个数据包,因此产生了一致的数据流,平滑了突发的流量;
*  当数据包具有相同尺寸的时候(例如ATM信元),每个时间片传输一个数据包的工作机制没有任何问题。但对于可变包长,这种工作机制可能存在一点问题,此时,最好每个时间片传输固定数目的字节。例如:如果每个时间片传输1024字节,那么一个时间片允许传输一个1024字节的包,两个512字节的包,或者 四个 256字节的包;
在概念上,漏桶算法可以作如下理解:   
* 到达的数据包(网络层的PDU)被放置在底部具有漏孔的桶中(数据包缓存);
*  漏桶最多可以排队b个字节,漏桶的这个尺寸受限于有效的系统内存。如果数据包到达的时候漏桶已经满了,那么数据包应被丢弃;
* 数据包从漏桶中漏出,以常量速率(r字节/秒)注入网络,因此平滑了突发流量。
基于漏桶的确定方法有以下优点:
*信源可以容易地保证它的通信量符合标准;
*网络可以容易地验证通信量是否符合规范;
*网络可以保证严格的延迟界限,避免一切又缓冲区溢出引起的丢失;
*由于服务质量根据严格的界限说明,用户能够验证网络是否提供了请求的服务质量。
在某些情况下,漏桶算法不能够有效地使用网络资源。因为漏桶的漏出速率是固定的参数,所以,即使网络中不存在资源冲突(没有发生拥塞),漏桶算法也不 能使某一个单独的流突发到端口速率。因此,漏桶算法对于存在突发特性的流量来说缺乏效率。而令牌桶算法则能够满足这些具有突发特性的流量。通常,漏桶算法 与令牌桶算法可以结合起来为网络流量提供更大的控制。

在流量整形中还存在另外一个流行的算法: 令牌桶算法(Token  Bucket)。有时人们将漏桶算法与令牌桶算法错误地混淆在一起。而实际上,这两种算法具有截然不同的特性并且为截然不同的目的而使用。它们之间最主要 的差别在于:漏桶算法能够强行限制数据的传输速率,而令牌桶算法能够在限制数据的平均传输速率的同时还允许某种程度的突发传输。

(2)令牌桶(Token Bucket)算法
令牌桶算法是网络流量整形(Traffic Shaping)和速率限制(Rate  Limiting)中最常使用的一种算法。典型情况下,令牌桶算法用来控制发送到网络上的数据的数目,并允许突发数据的发送。
令牌桶这种控制机制基于令牌桶中是否存在令牌来指示什么时候可以发送流量。令牌桶中的每一个令 牌都代表一个字节。如果令牌桶中存在令牌,则允许发送流量;而如果令牌桶中不存在令牌,则不允许发送流量。因此,如果突发门限被合理地配置并且令牌桶中有 足够的令牌,那么流量就可以以峰值速率发送。
令牌桶算法的基本过程如下:
假如用户配置的平均发送速率为r,则每隔1/r秒一个令牌被加入到桶中;
假设桶最多可以存发b个令牌。如果令牌到达时令牌桶已经满了,那么这个令牌会被丢弃;
当一个n个字节的数据包到达时,就从令牌桶中删除n个令牌,并且数据包被发送到网络;
如果令牌桶中少于n个令牌,那么不会删除令牌,并且认为这个数据包在流量限制之外;
算法允许最长b个字节的突发,但从长期运行结果看,数据包的速率被限制成常量r。

对于在流量限 制外的数据包可以以不同的方式处理:
它们可以被丢弃;
它们可以排放在队列中以便当令牌桶中累积了足够多的令牌时再传输;
它们可以继续发送,但需要做特殊标记,网络过载的时候将这些特殊标记的包丢弃。

这两种算法可以应用在数据传送端(Traffic Source)或者是路由器,来对传送的流量做整形。

3、Analysis
ns lab16.tcl
perl throughput.pl out.tr 0 1.0
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值