资讯专栏INFORMATION COLUMN

tcp协议 拥塞控制

focusj / 1904人阅读

摘要:在这个过程中如果出现了拥塞,则进入拥塞状态。进入拥塞状态也分两种情况等到超时重传超时,重传数据包。

补充tcp协议与滑动窗口
我们在向对端发送数据时,并不是一股脑子任意发送,因为TCP建立连接后,就是建立了一根管道,这跟管道上,实际上有很多的工作设备,比如路由器和交换机等等,他们都会对接收到的TCP包进行缓存,以便实现排序,然后发送,但是这些设备并不是只为一个TCP连接中转数据包,大量的网络包也许会耗尽存储空间,从而导致TCP连接的吞吐量急剧下降。为了避免这种情况的发送,TCP的设计必须是一种无私的协议,它必须去探测这种网络拥塞的问题,否则我们想想,一旦出现拥塞(判断是否丢包或者是否发生重传),如果TCP只能做重传,那么重传数据包会使得网络上的包更多,网络的负担更重,于是导致更大的延迟以及丢更多的包,于是会进入一个恶性循环,如果网络上的所有TCP连接都是如此行事的话,那么马上就会形成“网络风暴”,会拖垮整个网络,这也是一个灾难。那么TCP就应该能够检测出来这种状况,当拥塞出现时,要做自我牺牲,就像交通阻塞一样,每一辆车都应该把路给让出来,而不是再去抢路了。这说的就是拥塞控制。那是如何控制的呢?

首先,我们得看TCP是如何充分利用网络的,TCP实际上就是逐步探测这个通道的传输的最大能力,这个逐步探索就是我们要讲的慢启动算法,这个慢启动算法就是:新建立的连接不能一开始就大量发送数据包,而是应该根据网络状况,逐步地增加每次发送数据包的量。

具体的工作步骤就是:

慢启动算法:

发送方维护一个拥塞窗口,刚开始时,这个拥塞窗口(cwnd,congestion window)设置为1,这个1代表是一个MSS个字节。

如果每收到一个ACK,那么就指数增长这个cwnd(2,4,8,16,32,64)等,

实际上不会这么一直指数级增长下去,TCP会设置一个慢启动的阈值(ssthresh,slow start threshold,65535个字节) ,当cwnd >= ssthresh时,进入拥塞避免阶段。

拥塞避免阶段

每收到一个ACK时,cwnd = cwnd + 1/cwnd;

每当每过一个RTT时,cwnd = cwnd + 1;

这样放缓了拥塞窗口的增长速率,避免增长过快导致网络拥塞,慢慢的增加调整到网络的最佳值。在这个过程中如果出现了拥塞,则进入拥塞状态。
拥塞状态 那是如何判断出现拥塞状态呢?只要出现丢包就认为进入了拥塞状态。进入拥塞状态也分两种情况:
1) 等到RTO超时(重传超时),重传数据包。TCP认为这种情况太糟糕,反应也很强烈:

sshthresh = cwnd /2

cwnd 重置为 1

进入慢启动过程

快速重传
2)连续收到3个duplicate ACK时,重传数据包,无须等待RTO。此情况即为下面的快速重传。

【问题】什么情况下会出现3个duplicate ACK?

TCP在收到一个乱序的报文段时,会立即发送一个重复的ACK,并且此ACK不可被延迟。

如果连续收到3个或3个以上重复的ACK,TCP会判定此报文段丢失,需要重新传递,而无需等待RTO。这就叫做快速重传。

TCP Tahoe的实现和RTO超时一样。 TCP Reno的实现是:

sshthresh = cwnd

cwnd = cwnd /2

进入快速恢复算法——Fast Recovery

上面我们可以看到RTO超时后,sshthresh会变成cwnd的一半,这意味着,如果cwnd<=sshthresh时出现的丢包,那么TCP的sshthresh就会减了一半,然后等cwnd又很快地以指数级增涨爬到这个地方时,就会成慢慢的线性增涨。我们可以看到,TCP是怎么通过这种强烈地震荡快速而小心得找到网站流量的平衡点的。

快速恢复算法

TCP Reno

这个算法定义在RFC5681。快速重传和快速恢复算法一般同时使用。快速恢复算法是认为,你还有3个Duplicated Acks说明网络也不那么糟糕,所以没有必要像RTO超时那么强烈。 注意,正如前面所说,进入Fast Recovery之前,cwnd 和 sshthresh已被更新:

sshthresh = cwnd

cwnd = cwnd /2

然后,真正的Fast Recovery算法如下:

cwnd = sshthresh + 3 * MSS (3的意思是确认有3个数据包被收到了)

重传Duplicated ACKs指定的数据包

如果再收到 duplicated Acks,那么cwnd = cwnd +1

如果收到了新的Ack,那么,cwnd = sshthresh ,代表恢复过程结束,然后就进入了拥塞避免的算法了。

如果我们仔细思考一下上面的这个算法,你就会知道,上面这个算法也有问题,那就是——它依赖于3个重复的Acks。注意,3个重复的Acks并不代表只丢了一个数据包,很有可能是丢了好多包。但这个算法只会重传一个,而剩下的那些包只能等到RTO超时,于是,进入了恶梦模式——超时一个窗口就减半一下,多个超时会超成TCP的传输速度呈级数下降,而且也不会触发Fast Recovery算法了。

TCP New Reno

于是,1995年,TCP New Reno(参见 RFC 6582 )算法提出来:

当sender这边收到了3个Duplicated Acks,进入Fast Retransimit模式,开发重传重复Acks指示的那个包。如果只有这一个包丢了,那么,重传这个包后回来的Ack会把整个已经被sender传输出去的数据ack回来。如果没有的话,说明有多个包丢了。我们叫这个ACK为Partial ACK。

一旦Sender这边发现了Partial ACK出现,那么,sender就可以推理出来有多个包被丢了,于是乎继续重传sliding window里未被ack的第一个包。直到再也收不到了Partial Ack,才真正结束Fast Recovery这个过程。

我们可以看到,这个“Fast Recovery的变更”是一个非常激进的玩法,他同时延长了Fast Retransmit和Fast Recovery的过程。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/63930.html

相关文章

  • 搞定计算机网络面试,看这篇就够了(补充版)

    摘要:相对与上一个版本的计算机网路面试知识总结,这个版本增加了协议如何保证可靠传输包括超时重传停止等待协议滑动窗口流量控制拥塞控制等内容并且对一些已有内容做了补充。 相对与上一个版本的计算机网路面试知识总结,这个版本增加了 TCP协议如何保证可靠传输包括超时重传、停止等待协议、滑动窗口、流量控制、拥塞控制等内容并且对一些已有内容做了补充。 一 OSI与TCP/IP各层的结构与功能,都有哪些协...

    lylwyy2016 评论0 收藏0
  • Android 面试必备 - 计算机网络基本知识(TCP,UDP,Http,https)

    摘要:在网络层有协议协议协议协议和协议。而且,因为有确认机制三次握手机制,这些也导致容易被人利用,实现等攻击。没有的这些机制,较被攻击者利用的漏洞就要少一些。但也是无法避免攻击的,比如攻击缺点不可靠,不稳定。 简介 HTTP协议(超文本传输协议)和 UDP(用户数据包协议),TCP 协议(传输控制协议) TCP/IP是个协议组,可分为四个层次:网络接口层、网络层、传输层和应用层。在网络层有I...

    My_Oh_My 评论0 收藏0
  • 计算机网络

    摘要:是无状态的,协议是由协议构建的可进行加密传输身份认证的网络协议,比协议安全。因此当网络出现拥塞时,应当控制发送方的速率。在这种情况下,只是丢失个别报文段,而不是网络拥塞。 POST跟GET的区别 作用 GET用于获取资源,而POST用于传输实体 参数 GET的参数以字符串的格式出现在URL中,而POST的参数存储在请求实体中。 因为URL只支持ASCII码,故GET的参数如果存在中文...

    Rindia 评论0 收藏0
  • TCP协议详解

    摘要:传输控制协议概述最主要的特点是面向连接的运输层协议。应用程序在使用协议之前,必须先建立连接。当时,表明此报文段的发送发的数据已发送完毕,并要求释放运输连接窗口占字节。 传输控制协议 TCP 概述 TCP 最主要的特点 TCP 是面向连接的运输层协议。应用程序在使用 TCP 协议之前,必须先建立 TCP 连接。在传送数据完毕后,必须释放已经建立的 TCP 连接 每一条 TCP 连接只能...

    zhouzhou 评论0 收藏0
  • TCP/UDP协议

    摘要:没有拥塞控制网络出现拥塞并不会使源主机的发送速率降低很多实时应用如电话,实时视频会议等要求主机以恒定速率发送数据,并且允许在拥塞时有一些数据丢失,但不允许有太大的时延,就可以用,比如打视频电话,有一两帧卡顿影响并不大。Tcp协议(传输控制协议)tcp是面向连接的协议,在收发数据之前,必须与对方建立可靠的连接;三次握手:简单形象通俗描述: 主机A向主机B发出连接请求数据包:我想给你发数据,可以...

    Tecode 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<