如何确定TCP最大传输速度?
TCP
的传输速度,受限于发送窗⼝,接收窗⼝以及⽹络设备传输能⼒。
其中,窗⼝⼤⼩由内核缓冲区⼤⼩决定。如果缓冲区与⽹络传输能⼒匹配,那么缓冲区的利⽤率就达到了最⼤化。
如何计算网络传输能力呢?
⽹络是有「带宽」限制的,带宽描述的是⽹络传输能⼒
它与内核缓冲区的计量单位不同
:
带宽是单位时间内的流
ᰁ
,表达是「速度」,⽐如常⻅的带宽
100 MB/s
;
缓冲区单位是字节,当⽹络速度乘以时间才能得到字节数。
带宽时延积
BDP
决定⽹络中⻜⾏报⽂的⼤⼩。所谓【⻜⾏】,是指它们就在⽹络线路、路由器等⽹络设备上。
其中:
RTT
为⽹络时延。
由于发送缓冲区⼤⼩决定了发送窗⼝的上限,⽽发送窗⼝⼜决定了「已发送未确认」的⻜⾏报⽂的上限。因此,发送缓冲区不能超过「带宽时延积」。
发送缓冲区与带宽时延积的关系如下:
如果发送缓冲区「超过」带宽时延积,超出的部分就没办法有效的⽹络传输,同时导致⽹络过载,容易丢包;
如果发送缓冲区「⼩于」带宽时延积,就不能很好的发挥出⽹络的传输效率。
怎样调整缓冲区大小?
发送缓冲区⼤⼩可⾃⾏调节,三个数值分别为:动态范围的最⼩值,初始默认值,动态范围的最⼤值
接收缓冲区范围调节
接收缓冲区可以根据系统空闲内存的⼤⼩来调节接收窗⼝:
如果系统的空闲内存很多,就可以⾃动把缓冲区增⼤⼀些,这样传给对⽅的接收窗⼝也会变⼤,因⽽提升发 送⽅发送的传输数据数。反之,如果系统的内存很紧张,就会减少缓冲区,这虽然会降低传输效率,可以保证更多的并发连接正常⼯作发送缓冲区的调节功能是⾃动开启的,⽽接收缓冲区则需要配置 tcp_moderate_rcvbuf
为
1
来开启调节功能
调节
TCP
内存范围
根据实际场景调节的策略