`
494078416
  • 浏览: 77799 次
  • 性别: Icon_minigender_1
  • 来自: 青岛
社区版块
存档分类
最新评论

UDP数据包大小问题

阅读更多

在进行UDP编程的时候,我们最容易想到的问题就是,一次发送多少bytes好?

       当然,这个没有唯一答案,相对于不同的系统,不同的要求,其得到的答案是不一样的,这里仅对像ICQ一类的发送聊天消息的情况作分析,对于其他情况,或许也能得到一点帮助:
首先,我们知道,TCP/IP通常被认为是一个四层协议系统,包括链路层,网络层,传输层,应用层.UDP属于运输层,下面我们由下至上一步一步来看:
以太网(Ethernet)数据帧的长度必须在46-1500字节之间,这是由以太网的物理特性决定的.这个1500字节被称为链路层的MTU(最大传输单元).但这并不是指链路层的长度被限制在1500字节,其实这个MTU指的是链路层的数据区.并不包括链路层的首部和尾部的18个字节.所以,事实上,这个1500字节就是网络层IP数据报的长度限制.因为IP数据报的首部为20字节,所以IP数据报的数据区长度最大为1480字节.而这个1480字节就是用来放TCP传来的TCP报文段或UDP传来的UDP数据报的.又因为UDP数据报的首部8字节,所以UDP数据报的数据区最大长度为1472字节.这个1472字节就是我们可以使用的字节数。:)
当我们发送的UDP数据大于1472的时候会怎样呢?这也就是说IP数据报大于1500字节,大于 MTU.这个时候发送方IP层就需要分片(fragmentation).把数据报分成若干片,使每一片都小于MTU.而接收方IP层则需要进行数据报的重组.这样就会多做许多事情,而更严重的是,由于UDP的特性,当某一片数据传送中丢失时,接收方便无法重组数据报.将导致丢弃整个UDP数据报。
因此,在普通的局域网环境下,我建议将UDP的数据控制在1472字节以下为好.
进行Internet编程时则不同,因为Internet上的路由器可能会将MTU设为不同的值.如果我们假定MTU为1500来发送数据的,而途经的某个网络的MTU值小于1500字节,那么系统将会使用一系列的机制来调整MTU值,使数据报能够顺利到达目的地,这样就会做许多不必要的操作.鉴于 Internet上的标准MTU值为576字节,所以我建议在进行Internet的UDP编程时.最好将UDP的数据长度控件在548字节 (576-8-20)以内.

理论上,IP数据报的最大长度是65535字节,这是由IP首部16比特总长度字段所限制的。去除20字节的IP首部和8个字节的UDP首部,UDP数据报中用户数据的最长长度为65507字节。但是,大多数实现所提供的长度比这个最大值小。
我们将遇到两个限制因素。第一,应用程序可能会受到其程序接口的限制。socket API提供了一个可供应用程序调用的函数,以设置接收和发送缓存的长度。对于UDP socket,这个长度与应用程序可以读写的最大UDP数据报的长度直接相关。现在的大部分系统都默认提供了可读写大于8192字节的UDP数据报(使用这个默认值是因为8192是NFS读写用户数据数的默认值)。
第二个限制来自于TCP/IP的内核实现。可能存在一些实现特性(或差错),使IP数据报长度小于65535字节。
在SunOS 4.1.3下使用环回接口的最大IP数据报长度是32767字节。比它大的值都会发生差错。
但是从BSD/386到SunOS 4.1.3的情况下,Sun所能接收到最大IP数据报长度为32786字节(即32758字节用户数据)。
在Solaris 2.2下使用环回接口,最大可收发IP数据报长度为65535字节。
从Solaris 2.2到AIX 3.2.2,发送的最大IP数据报长度可以是65535字节。很显然,这个限制与源端和目的端的实现有关。
主机必须能够接收最短为576字节的IP数据报。在许多UDP应用程序的设计中,其应用程序数据被限制成512字节或更小,因此比这个限制值小。
由于IP能够发送或接收特定长度的数据报并不意味着接收应用程序可以读取该长度的数据。因此,UDP编程接口允许应用程序指定每次返回的最大字节数。如果接收到的数据报长度大于应用程序所能处理的长度,那么会发生什么情况呢?不幸的是,该问题的答案取决于编程接口和实现。
典型的Berkeley版socket API对数据报进行截断,并丢弃任何多余的数据。应用程序何时能够知道,则与版本有关(4.3BSD Reno及其后的版本可以通知应用程序数据报被截断)。
SVR4 下的socket API(包括Solaris 2.x) 并不截断数据报。超出部分数据在后面的读取中返回。它也不通知应用程序从单个UDP数据报中多次进行读取操作。TLI API不丢弃数据。相反,它返回一个标志表明可以获得更多的数据,而应用程序后面的读操作将返回数据报的其余部分。在讨论TCP时,我们发现它为应用程序提供连续的字节流,而没有任何信息边界。TCP以应用程序读操作时所要求的长度来传送数据,因此,在这个接口下,不会发生数据丢失。

在进行UDP编程的时候,我们最容易想到的问题就是,一次发送多少bytes好?
当然,这个没有唯一答案,相对于不同的系统,不同的要求,其得到的答案是不一样的,我这里仅对
像ICQ一类的发送聊天消息的情况作分析,对于其他情况,你或许也能得到一点帮助:
首先,我们知道,TCP/IP通常被认为是一个四层协议系统,包括链路层,网络层,运输层,应用层.
UDP属于运输层,下面我们由下至上一步一步来看:
以太网(Ethernet)数据帧的长度必须在46-1500字节之间,这是由以太网的物理特性决定的.
这个1500字节被称为链路层的MTU(最大传输单元).
但这并不是指链路层的长度被限制在1500字节,其实这这个MTU指的是链路层的数据区.
并不包括链路层的首部和尾部的18个字节.
所以,事实上,这个1500字节就是网络层IP数据报的长度限制.
因为IP数据报的首部为20字节,所以IP数据报的数据区长度最大为1480字节.
而这个1480字节就是用来放TCP传来的TCP报文段或UDP传来的UDP数据报的.
又因为UDP数据报的首部8字节,所以UDP数据报的数据区最大长度为1472字节.
这个1472字节就是我们可以使用的字节数。:)

当我们发送的UDP数据大于1472的时候会怎样呢?
这也就是说IP数据报大于1500字节,大于MTU.这个时候发送方IP层就需要分片(fragmentation).
把数据报分成若干片,使每一片都小于MTU.而接收方IP层则需要进行数据报的重组.
这样就会多做许多事情,而更严重的是,由于UDP的特性,当某一片数据传送中丢失时,接收方便
无法重组数据报.将导致丢弃整个UDP数据报.

因此,在普通的局域网环境下,我建议将UDP的数据控制在1472字节以下为好.
进行Internet编程时则不同,因为Internet上的路由器可能会将MTU设为不同的值.
如果我们假定MTU为1500来发送数据的,而途经的某个网络的MTU值小于1500字节,那么系统将会使用一系列的机
制来调整MTU值,使数据报能够顺利到达目的地,这样就会做许多不必要的操作.

鉴于Internet上的标准MTU值为576字节,所以我建议在进行Internet的UDP编程时.
最好将UDP的数据长度控件在548字节(576-8-20)以内.

---------------------------------------------------------------转载分割线------------------------------------------------------

经测试,局域网环境下,UDP包大小为1024*8,速度达到2M/s,丢包情况理想.

外网环境下,UDP包大小为548,速度理想,丢包情况理想.

分享到:
评论

相关推荐

    测量UDP 数据包延迟_python_代码_下载

    尝试不同的数据包大小! 同时测量来自多个发送主机的数据包延迟! 测量单向延迟(需要单独出售的单独硬件计时器以及往返延迟 保存每个数据包的延迟列表...到文件! 你说什么?普通人会ping做大部分这些事情吗?嗯...

    利用udp发送数据包

    利用udp发送百万数据包,每个数据包大小为1500bytes(其中数据为1472bytes)的耗时(us)

    linux下的UDP发包器

    可以利用原始套接字来完成发送自己填写的UDP数据包。整个程序由初始化原始套接口和发送UDP数据包两部分组成。UDP传输实体将用户数据加上UDP报头,形成UDP数据包,在UDP数据包上增加IP头部,形成IP数据包。 为了能够...

    UDP协议通信演示Delphi源码

    UDP包的大小问题 资料1:以太网的MTU是1500字节,IP包头占20个字节,UDP首部占8个字节,也就是说实际数据应该小于1472字节. 资料2:鉴于Internet上的标准MTU值为576字节,所以我建议在进行Internet的UDP编程时.最好将...

    Server_0.8_UDP_

    轻的CPU和RAM使用量少较小的数据包大小开销(不可靠的为1字节,可靠的数据包为4字节)简单的连接处理对等连接用于发送和阅读消息的帮助程序类多个数据通道不同的发送机制订购可靠可靠,无需订购可靠排序(仅最后一个...

    Android实现文件的分割和组装

    一般来说,在使用UDP数据包发送文件时,由于UDP数据包大小的限制,一个文件要放在几个UDP数据包里面发送,这就需要把一个文件分割成若干部分,分别放进若干个UDP数据包里面,在接收端,收到这些UDP数据包以后,再对...

    TCP和UDP协议发送数据包的大小方面的知识介绍

    来介绍一下TCP和UDP协议发送数据包的大小

    UDP服务器并发压力测试工具

    应用平台为windows,采用ACE practor模式封装的windows下的完成端口机制,保证并发测试的效果,每秒中我的电脑(4核,4G内存 3.2G主频,100M网卡)可以发送2800个左右的UDP数据包,每个数据包大小为100bytes。...

    udp压力测试.zip

    应用平台为windows,采用ACE practor模式封装的windows下的完成端口机制,保证并发测试的效果,每秒中我的电脑(4核,4G内存 3.2G主频,100M网卡)可以发送2800个左右的UDP数据包,每个数据包大小为100bytes。...

    C# 文件传输 UDP

    基于C#的udp文件传输,分为客户端和服务端,附带源码,支持自由更改数据包大小

    UDP 丢包率测试工具

    客户端使用UDP发送指定大小数据包,服务端收到后原样返回。客户端判断丢失率。包含工程、源码、可执行文件等

    TCP UDP调试工具sokitv1.0绿色版

    TCP/UDP测试工具,用来接收、发送、转发TCP或UDP数据包。 数据输入格式 发送区的编辑框内的字符会按照ascii值发送(多字节字符按照UTF8编码),如果需要发送十六进制原始数据,请将相应数值的ascii表示放进方括号中,...

    TCP/UDP 应用开发调试助手

    ——可以通过它来从网络上发送TCP/UDP数据包 ——支持16进制的发送和16进制接收显示,支持汉字以及文本发送 ——支持发送、接收字节数统计 ——支持自动发送和手动发送 ——最大特色,支持高精度(1ms)定时发送 ...

    asio_service_discovery:通过udp组播进行服务发现的组件。 它正在使用升压

    请注意,udp数据包的最大数据包大小受到限制。 该库支持正在运行的机器上udp数据包的最大大小(在我的机器上为〜8kb)。 但是在选择服务名称时请记住这一点。 但是,低于kb的任何内容都可以。 如果收到“消息过长”...

    udp_test.rar

    这个工具就是为了测试网络丢包和数据的突发性、数据量、数据包大小、发送一组数据的延时等相关性,找到相关性再对程序有针对性的调整。程序源码分两部分:1、Linux服务端程序,C语言;2、windows客户端程序,VS2015...

    UDP可靠传输代码(delphi)

    所以偶需要一个安全的UDP可以发送任意大小包,可以保证某些重要的包不会丢失,并且可以轻松穿透NAT来进行点对点通讯。 网上四处寻找未果SO自己动手写了一个。具有以下功能(本类是站在前人的肩膀上实现,基类为偶...

    LiteNetLib:适用于Mono和.NET的Lite可靠UDP库

    较小的数据包大小开销(不可靠为1字节,可靠数据包为4字节) 简单的连接处理 对等连接 用于发送和阅读消息的助手类 多个数据通道 不同的发送机制 订购可靠 可靠,无需订购 可靠排序(仅最后一个数据包可靠) 有序...

    tilerapktgen:Tilera数据包生成器

    Tilera数据包生成器该程序生成UDP数据包,并使用mPipe通过某些指定的接口以线速发送它们。 它也计算接收到的数据包的数量。 它是为TILEncore-Gx36制作的,但应该可以在其他Tilera设备上使用。 它计算一定范围的...

    一个小巧的网络监视工具,仅有235K,绿色无毒

    对于每个统计行,将显示以下信息:以太网类型(IPv4、IPv6、ARP)、IP协议(TCP、UDP、ICMP)、源地址,目标地址,源端口,目标端口,服务名称(http、ftp等)、数据包计数、总数据包大小、总数据大小、数据速度、...

    networktrafficview-x64

     Ethernet Type(IPv4、IPv6、ARP)、IP协议(TCP、UDP、ICMP)、信源地址、目的地地址、源端口、目的端口、服务名称(HTTP、FTP等)、数据包计数、总数据包大小、总数据大小,数据速度,最大数据速度,平均数据包...

Global site tag (gtag.js) - Google Analytics