TCP窗口

作者: RainingMan | 来源:发表于2019-08-02 16:30 被阅读0次

作者:林沛满
出处:Wireshark网络分析就是这么简单

1.每个TCP的包都含有“window size” (也就是win=)的信息。这个值表示发送窗口的大小吗?

这个不是发送窗口,
而是在向对方表明自己的接收窗口。
另,加入接收方处理数据的速度跟不上接收数据的速度,缓存就会被占满,从而导致接收窗口为0。

2.我如何在包里看出发送窗口的大小呢?

很遗憾,没有简单的办法。因为,当发送窗口是由接收窗口决定的时候,我们还可以通过“window size:”的值来判断。而当它由网络因素决定的时候,事情就会变得非常复杂。

3.发送窗口和MSS有什么关系?

发送窗口决定了一口气能发多少字节,而MSS决定了这些字节要分多少个包发完。举个例子,在发送窗口为16000字节的情况下,如果MSS为1000字节,那就需要发送16000/1000=16个包;

4.发送方在一个窗口里发出n个包,是不是就能收到n个确认包?

不一定,确认包一般会少一些。由于TCP可以累积起来确认,所以当收到多个包的时候,只需要确认最后一个就可以了。

5.经常听人说“TCP Window Scale”这个概念,他究竟和接收窗口有什么关系呢?

在TCP刚被发明的时候,全世界的网络贷款都很小,所以最大接收窗口被定义为65535字节。随着硬件的革命性进步,65535字节已经成为性能瓶颈了。怎么样才能扩展呢?TCP头中只给接受窗口溜了16bit,肯定无法突破65535字节的。
1992年的RFC1323中提出一个解决方案,就是在三次我我握手中,增加Window Scale信息放到TCP头之外的Options中(也就不需要修改TCP头的设计)。Window Scale的作用是向对方声明一个Shift count ,我们把它作为2的指数,再乘以TCP头中定义的接收窗口,就得到真正的TCP接收窗口了。如果IP A告诉IP B说它的Shift count是5。2^5等于32,这就意味着以后的(此次三次握手之后)IP A声明的接收窗口要乘以32才是真正的接收窗口值。

要注意Wireshark是根据Shift count计算出这个Win的数值,如果Wireshark抓包是没有抓到三次握手,Wireshark就不知道怎么计算了,所以有时候我们会看到莫名的一些很小的接收窗口值。还有些时候是防火墙识别不了Window Scale,因此对方无法获得Shift count,最终导致严重的性能问题。

相关文章

  • TCP/IP 协议(转)

    参考:TCP/IP 协议tcp窗口滑动以及拥塞控制解析TCP之滑动窗口(动画演示)

  • TCP窗口

    作者:林沛满出处:Wireshark网络分析就是这么简单 1.每个TCP的包都含有“window size” (也...

  • iOS TCP 连接原理

    TCP可靠传出的实现: 1). TCP连接的每一端都必须设有两个窗口(一个窗口发送,一个窗口接收), TCP的可靠...

  • TCP那些事儿

    目录: TCP是什么TCP报文结构TCP连接过程TCP状态转移TCP流量控制 —— 滑动窗口TCP拥塞控制TCP可...

  • TCP三次握手(转)

    建立连接:理解:窗口和滑动窗口TCP的流量控制TCP使用窗口机制进行流量控制什么是窗口?连接建立时,各端分配一块缓...

  • TCP-连接、断开和滑动窗口简介

    转载:TCP-连接、断开和滑动窗口简介 1.TCP概述TCP(Transmission Control Proto...

  • TCP的流量控制与拥塞控制机制

    参考:滑动窗口TCP的流量控制和拥塞控制 1 流量控制 利用滑动窗口机制实施流量控制 TCP协议里窗口机制有2种:...

  • TCP滑动窗口

    TCP是以一个段为单位的,如果每次只发一个段进行一次确认应答处理的话,将会导致通信性能的下降,尤其是往返时间较长的...

  • TCP滑动窗口

    https://www.cnblogs.com/alifpga/p/7675850.htmlhttps://www...

  • TCP滑动窗口

    一、复习review 1.1 多进程和多线程的对比 多线程模型需要处理SIGPIPE信号,因为多次去写就会触发SI...

网友评论

      本文标题:TCP窗口

      本文链接:https://www.haomeiwen.com/subject/hgwldctx.html