网络报文的长度

来源:互联网 发布:生活很无聊 知乎 编辑:程序博客网 时间:2024/05/21 22:25
 
    对于以太网环境下UDP传输中的数据包长度问题,首先要看TCP/IP协议,涉及到四层:链路层,网络层,传输层,应用层。
其中以太网(Ethernet)的数据帧在链路层,IP包在网络层,TCP或UDP包在传输层,TCP或UDP中的数据(Data)在应用层,它们的关系是:
             数据帧{IP包{TCP或UDP包{Data}}}
 在应用程序中我们用到的Data的长度最大是多少,直接取决于底层的限制。我们从下到上分析一下:
 在链路层,由以太网的物理特性决定了数据帧的长度为(46+18)-(1500+18),其中的18是数据帧的头和尾,46+18=64是以太网帧的最短帧长,1500+18=1518是最大帧长。也就是说数据帧的内容最大为1500,即MTU(Maximum Transmission Unit)为1500;
  (可是为什么我用wireshark抓下的包看到的帧头部是14字节,木有校验位4位?!,最短帧长是62?!)
 在网络层,因为IP包的首部要占用20字节,所以这的MTU为1500-20=1480;
 在传输层,对于UDP包的首部要占用8字节,所以这的MTU为1480-8=1472;
 所以,在应用层,你的Data最大长度为1472
 (当我们的UDP包中的数据多于MTU(1472)时,发送方的IP层需要分片fragmentation进行传输,而在接收方IP层则需要进行数据报重组,由于UDP是不可靠的传输协议,如果分片丢失导致重组失败,将导致UDP数据包被丢弃)。
 从上面的分析来看,在普通的局域网环境下,UDP的数据最大为1472字节最好(避免分片重组)。
 但在网络编程中,Internet中的路由器可能有设置成不同的值(小于默认值),Internet上的标准MTU值为576,所以Internet的UDP编程时数据长度最好在576-20-8=548字节以内。

如何查看路由的MTU值:
 MTU对我们的UDP编程很重要,那如何查看路由的MTU值呢?
 对于windows OS: ping -f -l <data_length> <gateway_IP>
 如:ping -f -l 1472 192.168.0.1
 如果提示:Packets needs to be fragmented but DF set.
 则表明MTU小于1500,不断改小data_length值,可以最终测算出gateway的MTU值;
 对于linux OS: ping -c <number> -M do -s <data_length> <gateway_IP>
 如: ping -c 1 -M do -s 1472 192.168.0.1
 如果提示 Frag needed and DF set……
 则表明MTU小于1500,可以再测以推算gateway的MTU。

如何修改本机的MTU

  修改方法如下:  

Windows平台下  

1、运行regedit  2、打开:HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters\Interfaces  3、Interfaces下有多个子项,每个子项对应一个网卡。请按如下方法选择网卡:  A、确定本机用来连接Internet的网卡或拨号连接的IP,如192.168.0.19;  B、用鼠标点击Interfaces上的子项,查看键值列表中的IPAddress项;  C、如果IPAddress的键值与A中的IP相同,即192.168.0.19,则该子项就是要找的网卡。  4、进入该子项,在右边的窗口里按鼠标右键,选择“新建”->“DWORD 值”,输入名称“MTU”,按回车。再用鼠标双击“MTU”,弹出修改窗口,填入MTU的值(一般为十进制的1480)。  填写前请先把基数设为十进制。 设置好后,需要重启机器才能生效。  Windows 7(XP、Vista未实测)  1、使用管理员权限运行cmd  2、使用netsh interface ipv4 show subinterfaces命令看看MTU以及本地连接名称。  3、使用netsh interface ipv4 set subinterface "连接名" mtu=300 store=persistent  (注:这里的连接名是你使用上面命令看到的MTU值对应的这个连接名,他在右边显示。)  附:1、此方法不用重启;2、如是ipv6就将上面的ipv4改成ipv6  Linux下可使用如下命令修改 需要root权限  ifconfig 网卡 MTU值  如 ifconfig eth0 mtu 1460  MaxMTU是最大的TCP/IP传输单元,在TCP/IP协议中,将要传输的数据分成较小的组进行传输,每个组的大小为576字节。Windows默认的字节为1500,这是以太网的分组标准。ADSL使用的 PPPoE略小于这个数值,一般为1492。而某些网站采用的MaxMTU大于1492,所以,可能导致某些网页不能访问。修改Windows默认的MaxMTU可以解决这个问题。不论是 PC机上安装的PPPoE软件或者是内置在Modem的 PPPoE软件,在使用中都有可能遇到这个问题。 如果使用路由器出现此种情况, 请在 防火墙配置 => 基本设定 里, 将MTU改为手工, 设置为 1492 即可. 那如何确定路由器从ISP获得的 MTU 为 1500, 请见附件圈出的位置.


原创粉丝点击