TCP滑动窗口、流量控制、拥塞控制

TCP滑动窗口、流量控制、拥塞控制

一、滑动窗口

上篇博客我们介绍了TCP报文结构、确认应答机制、超时重传机制、连接管理机制
TCP保证了可靠传输,但是失去了效率。那么怎么样尽可能提高传输效率呢???

我们讨论了确认应答策略:对每一个发送的数据段,都要给一个ACK确认应答,收到ACK后再发送下一个数据段。
这样做有一个比较大的缺点,就是性能较差,尤其是数据往返的时间较长的时候。

在这里插入图片描述
主机A大量的时间都消耗在了等待ACK上!

既然这样一发一收的方式性能较低,那么我们一次发送多条数据,就可以大大的提高性能 (其实是将多个段的等待时间重叠在一起了) !
在这里插入图片描述

  • 窗口大小指的是无需等待确认应答而可以继续发送数据的最大值。上图的窗口大小就是4000个字节 (四个段)。
  • 发送前四个段的时候,不需要等待任何ACK,直接发送;
  • 收到第一个ACK后,滑动窗口向后移动,继续发送第五个段的数据;依次类推;
  • 操作系统内核为了维护这个滑动窗口,需要开辟发送缓冲区来记录当前还有哪些数据没有应答;只有确认应答过的数据才能从缓冲区删掉;
  • 窗口越大,则网络的吞吐率就越高;

在这里插入图片描述

那么如果出现了丢包,如何进行重传?这里分两种情况讨论。

情况一: 数据包已经抵达,ACK被丢了。
在这里插入图片描述
这种情况下,部分ACK丢了并不要紧,因为可以通过后续的ACK进行确认!

情况二: 数据包就直接丢了。
在这里插入图片描述
在这里插入图片描述
2001 - 7000 接收端其实之前就已经收到了,被放到了接收端操作系统内核的接收缓冲区中。

这种搭配滑动窗口的机制被称为"高速重发控制" (也叫"快重传")。

二、流量控制

窗口大小越大,确实发送速度会更快~~ 但是窗口能无限大吗?

接收端处理数据的速度是有限的。如果发送端发的太快,导致接收端的缓冲区被打满,这个时候如果发送端继续发送,就会造成丢包,继而引起丢包重传等等一系列连锁反应。

因此TCP支持根据接收端的处理能力,来决定发送端的发送速度。这个机制就叫做流量控制 (Flow Control) !

在这里插入图片描述

接收方的接收速率如何进行量化?
接收方使用接收缓冲区的剩余空间大小来作为发送方发送速率(窗口大小)的参考数值!

在这里插入图片描述

如果接收端缓冲区满了,就会将窗口置为0;这时发送方不再发送数据,但是需要定期发送一个窗口探测数据段,使接收端把窗口大小告诉发送端。
在这里插入图片描述

接收端如何把窗口大小告诉发送端呢?回忆我们的TCP首部中,有一个16位窗口字段,就是存放了窗口大小信息:
在这里插入图片描述
16位数字最大表示65535,那么TCP窗口最大就是65535字节么?
实际上,TCP首部40字节选项中还包含了一个窗口扩大因子M,实际窗口大小是窗口字段的值左移M位~~

三、拥塞控制

流量控制是通过接收方的处理能力来衡量发送方的速率的。
难道只需要考虑接收方的处理速率吗?显然不是,还得考虑中间的这些转发节点的情况!
在这里插入图片描述
在这里插入图片描述
网络的环境是复杂的,网络环境也不是一成不变的~~
这就是拥塞控制!

流量控制是在控制发送方的窗口大小;拥塞控制也是在控制发送方的窗口大小。
那么有分歧的时候听谁的?谁小听谁的!!!(木桶原理)

TCP实现拥塞控制的具体方式是什么呢?
TCP引入慢启动机制,先发少量的数据探探路,摸清当前的网络拥堵状态,再决定按照多大的速度传输数据。

在这里插入图片描述
拥塞控制,归根结底是TCP协议想尽可能快的把数据传输给对方,但是又要避免给网络造成太大压力的折中方案~~

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

yyhgo_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值