天天看点

tcp滑动窗口大小设置_滑动窗口大小、TCP字段中16位窗口大小、MTU、MSS、缓存区大小有什么关系?(一)...

TCP中为了控制流量,里面包含了很多关于流控大小的参数,包括TCP字段中16位窗口大小,滑动窗口,还有MTU 最大传输单元, MSS 最大分解大小,还有内核socket接受和发送缓存区的大小,这些参数是怎么相互制约和共同完成流控的?

正文

tcp滑动窗口大小设置_滑动窗口大小、TCP字段中16位窗口大小、MTU、MSS、缓存区大小有什么关系?(一)...

MTU: Maximum Transmit Unit

最大传输单元,即物理接口(数据链路层)提供给其上层(通常是IP层)最大一次传输数据的大小;以普遍使用的以太网接口为例,缺省MTU=1500 Byte,这是以太网接口对IP层的约束,如果IP层有<=1500 byte 需要发送,只需要一个IP包就可以完成发送任务;如果IP层有> 1500 byte 数据需要发送,需要分片才能完成发送,这些分片有一个共同点,即IP Header ID相同。

MSS:Maximum Segment Size 

TCP提交给IP层最大分段大小,不包含TCP Header和 TCP Option,只包含TCP Payload ,MSS是TCP用来限制application层最大的发送字节数。如果底层物理接口MTU= 1500 byte,则 MSS = 1500- 20(IP Header) -20 (TCP Header) = 1460 byte,如果application 有2000 byte发送,需要两个segment才可以完成发送,第一个TCP segment = 1460,第二个TCP segment = 540。

A (MTU 1500) (MTU 1492) B

见上图,TCP SYN消息,A 发送给B 的MSS= 1460,告诉B,B发给A最大segment 为1460 byte。

TCP SYN消息,B发送给A的MSS= 1452,告诉A,A发给B最大segment 为1452 byte 。

但A最终能一次发给B多大的字节的segment呢???

我们给它取名为:A_Send_MSS,取决于两个值,一个是B的通告MSS= 1452;另一个是本地物理接口MTU的限制:1500-20-20= 1460。取这两者较小的一个值,则

A_Send_MSS = minimum ( 1452, 1460) = 1452

同理可得

B_Send_MSS = minimum ( 1460,1452)=1452

可以看出这两者最后是相同的,所以可以得到以下结论,通信双方最终的MSS = 双方较小MTU- 40 。

Socket发送和接收缓冲区大小

按照我的理解,socket将TCP实现细节封装成API,Socket虽然不等于TCP,但TCP的 send_buffer 和 receive_buffer 应该和socket 等同,用C语言的说法,就是指针相同,用通俗语言来说就是,相同的内存地址段。接收缓冲区receive_buffer 大小等同于自己通告的window size; 至于send_buffer 大小会影响application放入发送缓冲区的速率,但是它应该不是瓶颈,所以不再讨论它。

继续阅读