第5章运输层的拥塞控制.ppt

第5章运输层的拥塞控制

计算机网络 第 7 章 运输层的拥塞控制 四种拥塞控制的方法 慢开始 拥塞避免 快重传 快恢复 两个参数 拥塞窗口cwnd:发送方维持的一个状态变量,拥塞窗口的大小取决于网络的拥塞程度,并且动态地在变化。发送方让自己的发送窗口等于拥塞窗口。 慢开始门限ssthresh:其用法如下 当cwnd ssthresh时,使用慢开始算法; 当cwnd ssthresh时,停止使用慢开始算法而 改用拥塞避免算法 当cwnd = ssthresh时,既可使用慢开始算法, 也可使用拥塞避免算法。 慢开始算法的原理 由小到大逐渐增大发送窗口,也就是逐渐增大拥塞窗口; 在主机刚刚开始发送报文段时可先将拥塞窗口 cwnd 设置为一个最大报文段 MSS 的数值; 在每收到一个对新的报文段的确认后,将拥塞窗口增加至多一个 MSS 的数值; 每经过一个传输轮次,拥塞窗口 cwnd 就加倍; 用这样的方法逐步增大发送端的拥塞窗口 cwnd,可以使分组注入到网络的速率更加合理。 拥塞避免算法 条件:拥塞窗口cwnd 慢开始门限 ssthresh时,停止使用慢开始算法而改用拥塞避免算法; 原理:没经过一个往返时间RRT(即传输轮次),就把拥塞窗口cwnd 加1,而不是加倍; 拥塞窗口cwnd按线性规律缓慢增长,比慢开始算法的拥塞窗口增长速率缓慢得多。 要点 无论在慢开始阶段还是拥塞避免阶段,只要发送方判断网络出现拥塞(其依据就是没有按时收到确认): 要将慢开始门限ssthresh设置为出现拥塞时的发送窗口值的一半(但不能小于2) 拥塞窗口cwnd重新设置为1,执行慢开始算法; 目的:迅速减少主机发送到网络中的分组数,使得发生拥塞的路由器有足够时间把队列中积压的分组处理完毕。 慢开始和拥塞避免算法的实现举例 慢开始和拥塞避免算法的实现举例 慢开始和拥塞避免算法的实现举例 慢开始和拥塞避免算法的实现举例 慢开始和拥塞避免算法的实现举例 慢开始和拥塞避免算法的实现举例 慢开始和拥塞避免算法的实现举例 慢开始和拥塞避免算法的实现举例 慢开始和拥塞避免算法的实现举例 AIMI算法 Additive Increase 加法增大 Multiplicative Decrease 乘法减小 乘法减小 (multiplicative decrease) “乘法减小“是指不论在慢开始阶段还是拥塞避免阶段,只要出现一次超时(即出现一次网络拥塞),就把慢开始门限值 ssthresh 设置为当前的拥塞窗口值乘以 0.5。 当网络频繁出现拥塞时,ssthresh 值就下降得很快,以大大减少注入到网络中的分组数。 加法增大 (additive increase) “加法增大”是指执行拥塞避免算法后,当收到对所有报文段的确认就将拥塞窗口 cwnd增加一个 MSS 大小,使拥塞窗口缓慢增大,以防止网络过早出现拥塞。 必须强调指出 “拥塞避免”并非指完全能够避免了拥塞。利用以上的措施要完全避免网络拥塞还是不可能的。 “拥塞避免”是说在拥塞避免阶段把拥塞窗口控制为按线性规律增长,使网络比较不容易出现拥塞。 快重传和快恢复 快重传举例 快恢复算法 与快重传配合使用 过程: (1)发送方连续收到三个重复确认时,就执行“乘法减小”算法,把慢开始门限ssthresh减半,这是为了预防网络发生拥塞,请注意:接下去不执行慢开始算法(即拥塞窗口cwnd不设置为1); (2)而是把拥塞窗口cwnd设置为慢开始门限ssrhresh减半后的数值,然后开始执行拥塞避免算法(“加法增大”),使拥塞窗口缓慢地线性增大。 注意 在采用快恢复算法时,慢开始算法只是在TCP连接建立时和网络出现超时时才使用。见P212图5-27所示。 请做P222第5-39题 书后作业 P220 5-13 5-21(1) 5-23 5-28 5-38 5-39 5-41 5-46 课件制作人:谢希仁 课件制作人:谢希仁 当 TCP 连接进行初始化时,将拥塞窗口=1。图中的窗口单位不使用字节而使用报文段。 慢开始门限的初始值设置为 16 个报文段, 即 ssthresh = 16。 2 4 6 8 10 12 14 16 18 20 22 0 0 4 8 12 16 20 24 传输次数 拥塞窗口 cwnd 进入拥塞避免 发生超时 指数规律增长 线性规律增长 ssthresh = 16 慢开始 慢开始 拥塞避免 拥塞避免 更新后的 ssthresh = 12 进入拥塞避免 在执行慢开始算法时,拥塞窗口 cwnd 的初始值为 1,发送

文档评论(0)

1亿VIP精品文档

相关文档