网络传输小包数据的潜在问题

    同样数据量的buffer,比如1500字节的数据,分10包 x 150发送和1包 x·1500发送,对比如下:

(1)10包数据,需要10个20字节ip头信息,7字节帧前导,1字节帧首界定符及帧与帧之间的12字节的默认帧间距,而这些都是通常意义的网络带宽的一部分,所以小包会造成带宽的浪费。

(2)在存储转发的模型下,报文的收发及查表都需要访存,那么小包的处理,需要访存的次数x10,降低了cache命中的几率,而cache未命中,消耗的是cpu的时钟周期,所以小包处理增加了cpu的负担。

(3)150字节的包的时间间隔约为35ns,而1500的包的时间间隔约为300ns,35x10的间隔时间要大于1x300ns,所以小包处理增加了报文处理的时延。

    所以在x86的平台上,应尽量避免小包的发送,当然大包的大小也需要考虑交换机,路由器的最大MTU的设置而定,通常是1500字节为宜。


你可能感兴趣的:(网络)