什么是糊涂窗口综合症

当发送端应用进程产生数据很慢、或接收端应用进程处理接收缓冲区数据很慢,或二者兼而有之;就会使应用进程间传送的报文段很小,特别是有效载荷很小。 极端情况下,有效载荷可能只有1个字节;而传输开销有40字节(20字节的IP头+20字节的TCP头) 这种现象就叫糊涂窗口综合症

发送端引起的糊涂窗口综合症

如果发送端为产生数据很慢的应用程序服务(典型的有telnet应用),例如,一次产生一个字节。这个应用程序一次将一个字节的数据写入发送端的TCP的缓存。如果发送端的TCP没有特定的指令,它就产生只包括一个字节数据的报文段。结果有很多41字节的IP数据报就在互连网中传来传去。
解决的方法是防止发送端的TCP逐个字节地发送数据。必须强迫发送端的TCP收集数据,然后用一个更大的数据块来发送。发送端的TCP要等待多长时间呢?如果它等待过长,它就会使整个的过程产生较长的时延。如果它的等待时间不够长,它就可能发送较小的报文段。Nagle找到了一个很好的解决方法,发明了Nagle算法。

接收端引起的糊涂窗口综合症

接收端的TCP可能产生糊涂窗口综合症,如果它为消耗数据很慢的应用程序服务,例如,一次消耗一个字节。假定发送应用程序产生了1000字节的数据块,但接收应用程序每次只吸收1字节的数据。再假定接收端的TCP的输入缓存为4000字节。发送端先发送第一个4000字节的数据。接收端将它存储在其缓存中。现在缓存满了。它通知窗口大小为零,这表示发送端必须停止发送数据。接收应用程序从接收端的TCP的输入缓存中读取第一个字节的数据。在入缓存中现在有了1字节的空间。接收端的TCP宣布其窗口大小为1字节,这表示正渴望等待发送数据的发送端的TCP会把这个宣布当作一个好消息,并发送只包括一个字节数据的报文段。这样的过程一直继续下去。一个字节的数据被消耗掉,然后发送只包含一个字节数据的报文段。

对于这种糊涂窗口综合症,即应用程序消耗数据比到达的慢,有两种建议的解决方法。
1 Clark解决方法 Clark解决方法是只要有数据到达就发送确认,但宣布的窗口大小为零,直到或者缓存空间已能放入具有最大长度的报文段,或者缓存空间的一半已经空了。
2 延迟确认 第二个解决方法是延迟一段时间后再发送确认。这表示当一个报文段到达时并不立即发送确认。接收端在确认收到的报文段之前一直等待,直到入缓存有足够的空间为止。延迟的确认防止了发送端的TCP滑动其窗口。当发送端的TCP发送完其数据后,它就停下来了。这样就防止了这种症状。
迟延的确认还有另一个优点:它减少了通信量。接收端不需要确认每一个报文段。但它也有一个缺点,就是迟延的确认有可能迫使发送端重传其未被确认的报文段。
可以用协议来平衡这个优点和缺点,例如现在定义了确认的延迟不能超过500毫秒。

什么是糊涂窗口综合症相关推荐

  1. TCP 糊涂窗口综合症(silly window syndrome)与 rate-based 流控

    昨天同事给我看了一个有趣的 case,接收端抓包: 现象就是这样,但结论也很明显: ack 渐长,win 渐缩,有数据陆续到达 rcvbuff,但 app 尚未读取. ack 不变,win 渐长,没有 ...

  2. 糊涂窗口综合症和Nagle算法

    本篇文章转载自:http://www.cnblogs.com/zhaoyl/archive/2012/09/20/2695799.html,用于记录自己对于TCP网络中糊涂窗口综合症和Nagle算法的 ...

  3. TCP三次握手、糊涂窗口、粘包问题

    这是在学习中的总结,若有错误请大家不吝指正(^.^) 关于TCP/IP的三次握手: 当服务端的状态为LISTEN,客户端的状态为CLOSED时,客户端发起连接 客户端发送有SYN字段报文,此时状态为S ...

  4. 你还在为 TCP 重传、滑动窗口、流量控制、拥塞控制发愁吗?看完图解就不愁了...

    每日一句英语学习,每天进步一点点: 来自:小林coding 前言 前一篇「硬不硬你说了算!近 40 张图解被问千百遍的 TCP 三次握手和四次挥手面试题」得到了很多读者的认可,在此特别感谢你们的认可, ...

  5. [通俗易懂]深入理解TCP协议(下):RTT、滑动窗口、拥塞处理

    转自即时通讯网:http://www.52im.net/ 前言 此文为系列文章的下篇,如果你对TCP不熟悉的话,请先看看上篇<[通俗易懂]深入理解TCP协议(上):理论基础> . 上篇中, ...

  6. tcp欢动窗口机制_TCP协议中的窗口机制------滑动窗口详解

    一.窗口机制的分类 在TCP协议当中窗口机制分为两种: 1.固定的窗口大小 2.滑动窗口 二.固定窗口存在的问题 如下图所示: 我们假设这个固定窗口的大小为1,也就是每次只能发送一个数据,只有接收方对 ...

  7. 图解TCP 的重传、滑动窗口、流量控制和拥塞控制机制

    每日一句英语学习,每天进步一点点: 前言 前一篇「硬不硬你说了算!近 40 张图解被问千百遍的 TCP 三次握手和四次挥手面试题」得到了很多读者的认可,在此特别感谢你们的认可,大家都暖暖的. 来了,今 ...

  8. [计算机网络] - TCP 重传、滑动窗口、流量控制、拥塞控制

    转载自:https://blog.csdn.net/qq_34827674/article/details/105606205 1. 重传机制 1.1 超时重传 重传机制的其中一个方式,就是在发送数据 ...

  9. 传输层协议TCP—滑动窗口(6)

    1 传输控制 TCP(Transmission Control Protocol 传输控制协议)是一种面向连接的.可靠的.基于字节流的传输层通信协议.在前面的章节中,我们介绍了 TCP 连接的相关概念 ...

  10. 计算机网络TCP拥塞控制窗口大小变化、重传、滑动窗口、流量控制等

    转载自:[计算机网络] - TCP 重传.滑动窗口.流量控制.拥塞控制_3000~3500的数据早已被接收了,因为 ack 都到了 4000 了,已经意味着 4000 之前__浮生_的博客-CSDN博 ...

最新文章

  1. python小白-day6 ConfigParser模块
  2. Hd2087 剪花布条
  3. SurfaceView 和 GLSurfaceView
  4. [译]基于GPU的体渲染高级技术之raycasting算法
  5. php正则表达式函数案例,PHP正则表达式函数preg_replace用法实例分析
  6. editorloop 占用_速度控制 部分重复 语言学习软件 Loopman
  7. div生成图片_Vue生成分享海报(含二维码)
  8. Serial Old收集器和Parallel Old收集器
  9. pygame小游戏(接球小游戏)
  10. Oracle EBS二次开发简介
  11. Python 随机生成 范围内(周围) 经纬度 坐标信息
  12. python+opencv修改图像指定像素的值
  13. SBB:替代固氮酶对非共生固氮可能的贡献
  14. vim生成连续数字列
  15. MATLAB实现 有限长序列的线性卷积和圆周卷积
  16. CentOS7 挂载NTFS分区
  17. 如何从从U盘安装windows xp到EeePC的详细流程
  18. 华为破除魔咒:任正非的自我革命
  19. 基于Python的银行信贷风险可视化与预警建模
  20. ubuntu制作私有源

热门文章

  1. No matter how hard it is or no matter how bad it gets, I am going to make it!
  2. web开发技巧-Worker
  3. ACM-Week 2
  4. 【GDKOI2013】琪露诺的完美算法课
  5. MySQL 权限操作
  6. Android控件详解之网格控件
  7. Windows---diskpart命令的使用
  8. java hadoop是什么_hadoop是什么语言
  9. JQuery实现shift键多选
  10. jQuery DOM操作