网络中的大包和小包相关问题总结

简介: 网络中的大包和小包相关问题总结

所谓大包就是一个数据包内,包含的数据字段比较多。整个数据包最大不超过1500字节。小包也是一样的,就是包含的数据字段比较少,整个包最小可以在64字节。一般来说,数据包的大小主要由程序来控制。比如游戏,他要求强烈的实时性,低延迟。报文交互频繁,但是速度一定要快。游戏类的数据包基本都是小包。大包主要是,视频,下载之类的,因为这种报文需要尽可能的为你提供更高的下载速率。他的报文基本上都是最大的。小包一般用于控制,比如dns请求,网络游戏等。

如果你玩游戏,看网页,一般小包居多。如果你下载文件,看视频,大包居多。

路由设备在转发的过程中,其实转发的只是MAC跟IP,一般的路由都不会去窥探报文数据的。(越界的不算)。所以,小包的转发速度就意味着设备的转发性能。当然了,大包转发的速度一般来说会更低。大包的数据字段也是要转发传输的。协议不论,大包小包就是简单的 : 数据包的大小。

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

同样数据量的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字节为宜。

在网络情况良好的情况下,当然是一次发送一个大包更加快,因为这样就减少了接收和发送缓冲区确认的时间了。

在网络不佳的情况下,建议还是拆包发送比较好,因为这样就降低了丢包重传的成本。

如果你在应用层组包太小的话,会在发送缓冲区自动粘包发送的。

相关文章
|
人工智能 监控 安全
什么是网络即服务 (NaaS)?
我们经常听到云计算领域中有IaaS(基础设施即服务)、PaaS(平台即服务)、SaaS(软件即服务),但是你知道吗?在网络领域也有一种术语叫做NaaS(网络即服务),本文瑞哥就带大家揭开NaaS的神秘面纱,让我们直接开始!
2719 0
什么是网络即服务 (NaaS)?
|
2月前
|
5G 新制造
5G网络
5G网络
87 9
|
6月前
|
网络协议 API 网络架构
|
6月前
快速确定网络号的范围
该文介绍了如何通过子网掩码快速确定IP地址中的网络号,避免复杂计算。以IP地址192.168.1.10和子网掩码255.255.255.0为例,网络号是前三个字节(192.168.1),加上子网掩码中主机号部分的0(.0),得到网络号192.168.1.0。此外,文中还提供了IP地址与子网掩码的二进制转换方法。
78 6
|
6月前
|
存储 负载均衡 搜索推荐
|
6月前
|
存储 网络协议 程序员
惊鸿一瞥-网络初识
惊鸿一瞥-网络初识
71 0
|
网络协议 算法 网络架构
关于网络的知识总结(一)
关于网络的知识总结(一)
197 0
|
弹性计算 Kubernetes 负载均衡
一次网络不通“争吵”引发的思考
一次网络不通“争吵”引发的思考
56317 47
|
SQL 网络协议 网络性能优化
网络七层协议详解
网络七层协议详解
423 1
|
网络协议 程序员 网络架构
网络初识必知会
网络初识必知会
50 0