TCP的滑动窗口机制

网络的错误检测和补偿机制非常复杂。

一、等待超时时间(返回ACK号的等待时间)

当网络繁忙时会发生拥塞,ACK号的返回变慢,较短的等待时间会导致频繁的数据重传,导致本就拥塞的网络雪上加霜。如果等待时间过长,包的重传又会出现很大的延迟,也会导致网络的速度变慢。根据服务器物理距离的远近,ACK号的返回时间也会产生很大的波动,而且我们还必须考虑到拥塞带来的影响。

TCP采用了动态调整等待时间的方法,根据ACK号的返回时间来调整等待时间。

二、滑动窗口

滑动窗口:发送一个包之后,不等待ACK号返回,而是直接发送后续的一系列包,充分利用ACK号的等待时间。

一来一回的ACK等待方式不会出现发送与处理速度不匹配的情况。但不等返回ACK号就连续发送包,就会出现发送频率超过接收方处理能力的情况。

当接收方的缓冲区溢出后,后面的数据就进不来了,会导致数据丢失。

滑动窗口处理这个问题的具体方式是,接收方将数据暂存到缓冲区并执行接收操作。当接收操作完成后,接收缓冲区中的控件会被释放出来,再通过TCP头部中的窗口字段将自己能接收的数据量告诉发送方。这样,发送方就不会发送过多的数据,导致超出接收方的处理能力。

序号、ACK号与其他数据一样,发送和接收操作都是双向进行的。

能够接收的最大数据量称为窗口大小。是TCP调优参数中非常有名的一个。

总结一下:

首先,协议栈会检查收到的数据块和TCP头部的内容,判断是否有数据丢失,如果没有问题则返回ACK号。

然后,协议栈将数据块暂存到接收缓冲区中,并将数据块按顺序连接起来还原出原始的数据。

最后将数据交给应用程序。

具体来说,协议栈会将接收到的数据复制到应用程序指定的内存地址中,然后将控制流程交回应用程序。将数据交给应用程序之后,协议栈还需要找到合适的时机向发送方发送窗口更新

相关推荐

  1. TCP重传、滑动窗口、流量控制、拥塞控制机制

    2023-12-11 07:54:06       22 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-11 07:54:06       91 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-11 07:54:06       97 阅读
  3. 在Django里面运行非项目文件

    2023-12-11 07:54:06       78 阅读
  4. Python语言-面向对象

    2023-12-11 07:54:06       88 阅读

热门阅读

  1. OpenGL 着色器程序的保存和加载(二进制)

    2023-12-11 07:54:06       62 阅读
  2. QList 方法

    2023-12-11 07:54:06       54 阅读
  3. 雪花算法:分布式系统的关键艺术

    2023-12-11 07:54:06       55 阅读
  4. 《C++20设计模式》---原型模式学习笔记代码

    2023-12-11 07:54:06       51 阅读
  5. Linux 定时任务备份MySQL数据库

    2023-12-11 07:54:06       57 阅读
  6. Mybatis-plus中wrapper的区别

    2023-12-11 07:54:06       57 阅读
  7. react表单-受控

    2023-12-11 07:54:06       60 阅读
  8. c++模板学习笔记

    2023-12-11 07:54:06       48 阅读