• 【计算机网络】运输层:糊涂窗口综合征即解决方法


    【糊涂窗口综合征产生的条件】

    当发送应用程序产生数据很慢,或接受应用程序读取数据很慢,或两者都有。

    【发送端产生的症状】

    发送数据的报文段很小,引起操作效率的降低。

    例:若TCP发送的报文段只包括一个字节的数据,但是要发送41字节的数据报(20个字节TCP首部和20字节的IP首部)才传送1字节的数据。数据的传送效率是1/41,表示在非常低效率地使用网络的容量。

    【解决方法】

    防止发送端的TCP逐个字节地发送数据。必须强迫发送端的TCP收集数据,然后用一个更大的数据块来发送。

    发送端的TCP的等待时间影响很大,如果等待时间过长,就会使整个过程产生较长的实验。如果等待时间不够长,就可能发送较小的报文段。

    【Nagle算法】用于发送端的TCP

    (1)发送端的TCP将它从发送应用程序收到的第一块数据发送出去,哪怕只有一个字节

    (2)在发送第一个报文段以后,发送端的TCP就在输出缓存中累积数据并等待;或者接受端的TCP发送一个确认,或者数据已累计到可以装成一个最大的报文段,在这个时候,发送端的TCP就可以发送这个报文段

    (3)重复(2)

    优点:考虑到应用程序产生数据的速率,以及网络运输数据的速率。若应用程序比网络快,则报文段就更大(最大报文段)。若应用程序比网络慢,则报文段就比较小(小于最大报文段)

    【接受端产生的症状】

    如果接受端为消耗数据很慢的应用程序访问,比如一次只消耗一个字节。假定发送应用程序产生了1000字节的数据块,但接收应用程序每次只读取1字节的数据。如果发送端的发送的数率比较快,接受端的TCP输入缓存会满。接受端 的TCP就通知窗口大小为0,表示发送端必须停止发送数据。

    接受应用程序从接收端的TCP输入缓存读取一个字节的数据,输入缓存就有了1字节的空间。接受端的TCP宣布窗口大小为1字节,发送端的TCP会只发一个字节数据的报文段。这样的过程一直继续下去。一个字节的数据被消耗掉,然后再发送只包含一个字节数据的报文段。

     对于应用程序消耗数据比到达的慢产生的糊涂窗口综合征,有两种建议解决方法:

    Clark解决方法:

    只要有数据到达就发送确认,但宣布的窗口大小为0,直到或者缓存空间已能放入具有最大长度的报文段,或者缓存空间的一半已经空了。

    延迟的确认:

    一个报文段到达时并不立即发送确认。接受端在确认收到报文段之前一直等待,直到缓存有足够的空间为止。

    延迟的确认

    (1)防止了发送端的TCP滑动其窗口,当发送端的TCP发送完数据后,它就停下来了。

    (2)减少了通信量。接受端不需要确认每一个报文段。

    但是,延迟的确认可能迫使发送端重传其未被确认的报文段。

    可以用协议来平衡这个优点和缺点,比如,定义确认的延迟不能超过500毫秒。

  • 相关阅读:
    关于iframe的页面加载出现滚动条的问题
    VUE 组件传值 $emit之 $event和arguments
    【原创】技术出身的我,如何做好一个管理者?
    Java学习笔记4.6.1 格式化 - DateFormat类
    基因检测技术的发展与创新:安全文件数据传输的重要作用
    如何在你的 wordpress 网站中添加搜索框
    Java SE 13 新增特性
    纯代码方式杀死指定进程名的进程(Linux&Windows)
    一、Linux 入门、VM 与 Linux 的安装
    【Windows】Edge浏览器自动更新服务启用选禁用被拒绝访问的解决方案
  • 原文地址:https://blog.csdn.net/m0_52043808/article/details/126691365