免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 73191 | 回复: 12
打印 上一主题 下一主题

UDP数据包允许的最大数据长度是多少? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-08-06 11:37 |只看该作者 |倒序浏览
RT,如果超出这个长度会如何处理呢?

论坛徽章:
0
2 [报告]
发表于 2010-08-06 11:45 |只看该作者
标识UDP长度的字段是16位数字,也就是最长不超过2^16字节,包括UDP首部8字节,楼主可以自己计算下。

数据超过UDP最大长度就分组嘛,具体怎么分就是更高层协议去规定了,也就是应用层的协议。

论坛徽章:
0
3 [报告]
发表于 2010-08-06 14:49 |只看该作者
在进行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)以内.

论坛徽章:
0
4 [报告]
发表于 2010-08-06 16:31 |只看该作者
udp 理论长度 2^16 - udp head - iphead

论坛徽章:
0
5 [报告]
发表于 2010-08-06 16:48 |只看该作者
最好不要超过512个字节,因为游戏系统的实现不支持太大的udp包。具体可以看tcp/ip 详解卷1的udp一节。

论坛徽章:
0
6 [报告]
发表于 2010-08-06 20:03 |只看该作者
65507
封装成 IP 后,大小超出 PMTU 的分组将可能被 fragmented。
如果设置了 Don't Frag,超出 PMTU 的分组将不能被发送。

特别地,IPv4 允许路由器对分组重新 fragment,但 IPv6 要求通讯的主机选择较小的分组大小,或者进行 Path MTU Discovery。

论坛徽章:
0
7 [报告]
发表于 2010-08-06 20:15 |只看该作者
65507 字节 = 65535 - 20 - 8,是一个理论值。

我建议您在设计程序的时候选择小于 PMTU 的 IP 分组大小,因为大于这个数值的分组可能被分片(否则无法发送),而分组交换的网络是不可靠的,存在着丢包。

IP 协议的发送方不做重传。接收方只有在收到全部的分片后才能 reassemble 并送至上层协议处理代码,否则在应用程序看来这些分组已经被丢弃。

假定同一时刻网络丢包的概率是均等的,那么较大的 IP datagram 必然有更大的概率被丢弃,因为只要丢失了一个 fragment,就导致整个 IP datagram 接收不到。不超过 PMTU 的分组是没有这个问题的。

一般地,在局域网中,UDP 分组的大小限制在 1472 字节内是安全的;在距离较近(100km 以内)的广域网中,1400 字节较为安全;距离较远的时候(如中美之间),我建议控制在 1300 字节,甚至 1200 字节。需要根据实际网络情况做出进一步的调整。

论坛徽章:
0
8 [报告]
发表于 2010-08-06 22:16 |只看该作者
在进行UDP编程的时候,我们最容易想到的问题就是,一次发送多少bytes好?   
当然,这个没有唯一答案,相对于 ...
rain_fish 发表于 2010-08-06 14:49



    学习了.

论坛徽章:
0
9 [报告]
发表于 2010-08-06 22:17 |只看该作者
65507 字节 = 65535 - 20 - 8,是一个理论值。

我建议您在设计程序的时候选择小于 PMTU 的 IP 分组大小, ...
langue 发表于 2010-08-06 20:15



    学习了.

论坛徽章:
0
10 [报告]
发表于 2012-08-13 11:54 |只看该作者
回复 3# rain_fish


    3Q, your explation is quite good!
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP