计算机网络——TCP拥塞控制

TCP拥塞控制的概念

在某计算机网络中如果一段时间里某种需要使用的资源的量超过网络中对这种资源的需求量就会产生拥塞,可以简单理解为供大于求就会产生网络拥塞。若网络中产生拥塞那么网络的性能就会变坏,整个网络的吞吐量就会随输入负荷而增大。我们要注意拥塞控制与流量控制的不同——拥塞控制是网络中一个全局性的概念,它涉及到整个网络系统中的所有主机与路由器,然而流量控制只是网络中一个局部性的概念,它往往指的是网络中某主机对某主机或者某主机对路由器等发送端和接收端之间点对点通信量的控制。

TCP拥塞控制的4种算法

在计算机网络中,发送端的主机在确定发送报文段的速率时,需要考虑两个因素:一是局部因素即接收端的接收能力,二是全局因素即网络拥塞程度。所以,TCP协议要求发送端维护接收端窗口和拥塞窗口。

  1. 接收端窗口rwnd:接收端窗口即接缓存大小所许诺的最新窗口值,反映了接收端的容量(每次接收端的容量在接收端返回给发送端确认帧时会告诉发送端)
    注:接收方总有足够大的空间
  2. 拥塞窗口cwnd:拥塞窗口是发送端根据自己估计的网络拥塞程度设置的窗口值,它反映了网络当前的容量

根据以上,我们不难看出要最大程度的控制网络拥塞情况又兼顾到网络传输效率当接收端窗口rwnd小于拥塞窗口cwnd时发送端窗口上限值应该为接收端窗口,当接收端窗口rwnd大于拥塞窗口cwnd时发送端窗口上限值应该为拥塞端窗口。
所以发送窗口的上限值=Min[rwnd,cwnd]
也就是说,rwnd和cwnd中较小的控制发送方发送数据的速率。

1.慢开始算法

  • 在主机刚刚开始发送报文段时可先设置拥塞窗口cwnd=1,也就是设置了一个最大报文段长度MSS的数值
  • 在每次收到一个新的报文段的确认后,将拥塞窗口加1,也就是增加一个MSS的数值。

对于以上两条慢开始算法的精髓,有一个如下的完整过程更容易理解。
0.由于当主机刚刚开始发送报文段时设置拥塞窗口为1,由于接收端窗口足够大所以此时发送端窗口为拥塞窗口与接收端窗口最小值也就是1。
1.第一轮传输:此时发送方发送一个报文段当接收方收到此报文段后会返回给发送方一个确认,当发送方收到确认后将拥塞窗口加1那么此时拥塞窗口为2。
2.第二轮传输:此时拥塞窗口为2,发送方窗口为接收端窗口与拥塞窗口的最小值也就是2,发送方在此轮传输可以发送两个报文段。在发送方发送第一个报文段并且接收方收到后,接收方会返回一个确认段给发送方,当接收方收到确认段后拥塞窗口加1为3。在发送方发送第二个报文段并且接收方收到后,接收方会返回一个确认段给发送方,当接收方收到确认段后拥塞窗口加1为4.
第三轮传输:…
在这里插入图片描述

我们对Markdown编辑器进行了一些功能拓展与语法支持,除了标准的Markdown编辑器功能,我们增加了如下几点新功能,帮助你用它写博客:

  1. 全新的界面设计 ,将会带来全新的写作体验;
  2. 在创作中心设置你喜爱的代码高亮样式,Markdown 将代码片显示选择的高亮样式 进行展示;
  3. 增加了 图片拖拽 功能,你可以将本地的图片直接拖拽到编辑区域直接展示;
  4. 全新的 KaTeX数学公式 语法;
  5. 增加了支持甘特图的mermaid语法1 功能;
  6. 增加了 多屏幕编辑 Markdown文章功能;
  7. 增加了 焦点写作模式、预览模式、简洁写作模式、左右区域同步滚轮设置 等功能,功能按钮位于编辑区域与预览区域中间;
  8. 增加了 检查列表 功能。

2.拥塞避免算法

  • 发送端的拥塞窗口cwnd每经过一个往返时延RTT就增加一个MSS的大小,通常表现为按线性规律增长。(此处与慢开始算法每收到一个确认报文段拥塞窗口就增加一个MSS不同,在不同条件下拥塞窗口增加一个MSS也是慢开始算法原理与拥塞避免算法原理的最大区别)
    在网络系统全局中为了网络传输效率刚开始时采用慢开始算法,当发送端口到达一定大小时为了避免过早拥塞会改为拥塞避免算法。为了防止拥塞窗口cwnd的增长引起网络阻塞,还需要一个状态量,就是慢开始门限值ssthresh,其使用方法如下:
    当cwnd<ssthresh时,使用慢开始算法。
    当cwnd>ssthresh时,改用拥塞避免算法。
    当cwnd=ssthresh时,既可以用慢开始算法,也可以用拥塞避免算法。
    在网络系统中无论哪个阶段,只要发送方判断网络出现拥塞,就会把慢开始门限值ssthresh设置为出现拥塞时的发送窗口值的一半但是不能小于2,再把拥塞窗口重新设置为1,执行慢开始算法。这样就可以迅速减少主机发送到网络中的分组数,使网络系统中的路由器有足够的时间把队列中积压的分组处理完毕。
    现有下面一系列过程图来详细讲解
    1.当TCP连接进行初始化时将拥塞窗口设置为1,慢开始门限ssthresh初值设置为16。发送端的发送窗口不能超过拥塞窗口cwnd和rwnd中的最小值。假定接收端窗口足够大,所以现在发送窗口数值等于拥塞。
    在这里插入图片描述
    2.当拥塞窗口cwnd由慢开始算法(第0-4传输轮次)增长到慢开始门限值ssthresh时,就改为执行拥塞避免算法(第4-12传输轮次),拥塞窗口按照线性规律增长。
    在这里插入图片描述
    3.假定拥塞窗口的数值增长到24时(第12传输轮次开始时),网络出现超时,表明网络拥塞了。此时把拥塞窗口置为1,门限值ssthresh置为12,并执行慢开始算法(第13-17传输轮次)。当cwnd=12时改为执行拥塞避免算法(第17-21传输轮次),拥塞窗口按性线规律增长,每经过一个往返时延就增加一个MSS的大小。
    在这里插入图片描述

3.快重传算法

在网络系统中,接收方的功能除了收到报文段整理保存再交付给上一层还要每收到一个失序的报文段后就立刻发出重复的确认。这个功能可以让发送方知道有报文段没有到达接收方。网络系统中设定,只要发送方连续收到3个重复确认就应当立即重传对方还没收到的报文段。如下图所示:
在这里插入图片描述

4.快恢复算法

  • 当发送端收到3个重复的ACK时,就重新设置慢开始门限ssthresh为当前拥塞窗口的一半。
  • 然后设置拥塞窗口为新的sstresh。(拥塞避免算法中发生拥塞时ssthresh设置为当前拥塞窗口的一半,拥塞窗口设置为1)
  • 如果此时发送窗口值还允许发送报文段,就按拥塞避免算法继续发送报文段。
    在这里插入图片描述

  1. mermaid语法说明 ↩︎

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值