简介

最大传输单元(Maximum Transmission Unit,MTU)用来通知对方所能接受数据服务单元的最大尺寸,说明发送方能够接受的有效载荷大小。
image.jpeg
是包或帧的最大长度,一般以字节记。如果MTU过大,在碰到路由器时会被拒绝转发,因为它不能处理过大的包。如果太小,因为协议一定要在包(或帧)上加上包头,那实际传送的数据量就会过小,这样也划不来。大部分操作系统会提供给用户一个默认值,该值一般对用户是比较合适的。

注:MTU是对二层以上的约束,不包含二层本身,如果MTU为1500字节(默认值也是1500),那么最终报文最大就是1514字节(包含CRC就是1518字节),包含14字节的二层头(DMAC、SMAC、协议)

具体限制结合:以太网帧下限64字节,上限1518字节进行了解

定义:各种为网络对数据帧都有一个大小限制,这个值就是MTU。
image.jpeg

需要注意的是,区别两种帧封装格式:802标准帧和以太网帧
1,在802标准定义的帧格式中,长度字段是指它后续数据的字节长度,
但不包括 CRC 检验码**。RFC 1042(IEEE 802)
2,RFC 894(以太网)

所以,以太网帧报头为目的地址6+源地址6+类型2+CRC 4=18bytes
而802帧没有CRC,所以为14bytes。Sniffer采用的是802帧为14bytes
一般的我们常用的是以太网和IEEE 802.3的限制分别为1500和1492字节。如下图:
image.jpeg
由于以太网EthernetII最大的数据帧是1518Bytes这样,刨去以太网帧的帧头(DMAC目的地址MAC48bit=6Bytes+SMAC源MAC地址48bit=6Bytes+Type域2bytes)14Bytes和帧尾CRC校验部分4Bytes(这个部门有时候大家也把它叫做FCS),那么剩下承载上层协议的地方也就是Data域最大就只能有1500Bytes. 这个值我们就把它称之为MTU。

以太网的MTU是1500,再减去PPP的包头包尾的开销(8Bytes),就变成1492(有的就是考虑兼容ppp的包头所以才是1492,纯互联网的话就没有这个,可以为1500)。

MSS就是TCP数据包每次能够传输的最大数据分段。为了达到最佳的传输效能TCP协议在建立连接的时候通常要协商双方的MSS值,这个值TCP协议在实现的时候往往用MTU值代替(需要减去IP数据包包头的大小20Bytes和TCP数据段的包头20Bytes)所以往往MSS为1460。通讯双方会根据双方提供的MSS值得最小值确定为这次连接的最大MSS值。

先说说这MTU最大传输单元,这个最大传输单元实际上和链路层协议有着密切的关系,让我们先仔细回忆一下EthernetII帧的结构DMAC+SMAC+Type+Data+CRC。由于以太网传输电气方面的限制,每个以太网帧都有最小的大小64bytes,最大不能超过1518bytes,对于小于或者大于这个限制的以太网帧我们都可以视之为错误的数据帧,一般的以太网转发设备会丢弃这些数据帧。(注:小于64Bytes的数据帧一般是由于以太网冲突产生的“碎片”或者线路干扰或者坏的以太网接口产生的,对于大于1518Bytes的数据帧我们一般把它叫做Giant帧,这种一般是由于线路干扰或者坏的以太网口产生)

由于以太网EthernetII最大的数据帧是1518Bytes这样,刨去以太网帧的帧头(DMAC目的MAC地址48bit=6Bytes+SMAC源MAC地址48bit=6Bytes+Type域2bytes)14Bytes和帧尾CRC校验部分4Bytes(这个部门有时候大家也把它叫做FCS),那么剩下承载上层协议的地方也就是Data域最大就只能有1500Bytes这个值我们就把它称之为MTU。这个就是网络层协议非常关心的地方,因为网络层协议比如IP协议会根据这个值来决定是否把上层传下来的数据进行分片。就好比一个盒子没法装下一大块面包,我们需要把面包切成片,装在多个盒子里面一样的道理。

当两台远程PC互联的时候,它们的数据需要穿过很多的路由器和各种各样的网络媒介才能到达对端,网络中不同媒介的MTU各不相同,就好比一长段的水管,由不同粗细的水管组成(MTU不同 :))通过这段水管最大水量就要由中间最细的水管决定。

对于网络层的上层协议而言(我们以TCP/IP协议族为例)它们对水管粗细不在意它们认为这个是网络层的事情。网络层IP协议会检查每个从上层协议下来的数据包的大小,并根据本机MTU的大小决定是否作“分片”处理。分片最大的坏处就是降低了传输性能,本来一次可以搞定的事情,分成多次搞定,所以在网络层更高一层(就是传输层)的实现中往往会对此加以注意!有些高层因为某些原因就会要求我这个面包不能切片,我要完整地面包,所以会在IP数据包包头里面加上一个标签:DF(Donot Fragment)。这样当这个IP数据包在一大段网络(水管里面)传输的时候,如果遇到MTU小于IP数据包的情况,转发设备就会根据要求丢弃这个数据包。然后返回一个错误信息给发送者。这样往往会造成某些通讯上的问题,不过幸运的是大部分网络链路都是MTU1500或者大于1500。

对于UDP协议而言,这个协议本身是无连接的协议,对数据包的到达顺序以及是否正确到达不甚关心,所以一般UDP应用对分片没有特殊要求。

对于TCP协议而言就不一样了,这个协议是面向连接的协议,对于TCP协议而言它非常在意数据包的到达顺序以及是否传输中有错误发生。所以有些TCP应用对分片有要求—-不能分片(DF)。

PPPOE与MTU

花开两朵,各表一枝,说完MTU的故事我们该讲讲今天的第二个猪脚—-PPPoE所谓PPPoE就是在以太网上面跑PPP协议,有人奇怪了,PPP协议和Ethernet不都是链路层协议吗?怎么一个链路层跑到另外一个链路层上面去了,难道升级成网络层协议了不成。其实这是个误区:就是某层协议只能承载更上一层协议**

为什么会产生这种奇怪的需求呢?这是因为随着宽带接入(这种宽带接入一般为Cable Modem或者xDSL或者以太网的接入)由于以太网缺乏认证计费机制而传统运营商是通过PPP协议来对拨号等接入服务进行认证计费的,所以就出了这么一个怪胎:PPPoE。(有关PPPoE的详细介绍参见V大以及本站其他成员的一些介绍文章,我就不啰里啰唆的了)

PPPoE带来了好处,也带来了一些坏处,比如:二次封装耗费资源,降低了传输效能等等,这些坏处俺也不多说了,最大的坏处就是PPPoE导致MTU变小了以太网的MTU是1500,再减去PPP的包头包尾的开销(8Bytes),就变成1492

如果两台主机之间的某段网络使用了PPPoE那么就会导致某些不能分片的应用无法通讯。

这个时候就需要我们调整一下主机的MTU,通过降低主机的MTU,这样我们就能够顺利地进行通讯了。

当然对于TCP应用而言还有另外的解决方案。马上请出今天第三位猪脚:MSS。

MSS最大传输大小的缩写,是TCP协议里面的一个概念。MSS就是TCP数据包每次能够传输的最大数据分段。为了达到最佳的传输效能TCP协议在建立连接的时候通常要协商双方的MSS值,这个值TCP协议在实现的时候往往用MTU值代替(需要减去IP数据包包头的大小20Bytes和TCP数据段的包头20Bytes)所以往往MSS为1460。通讯双方会根据双方提供的MSS值得最小值确定为这次连接的最大MSS值。

我们回过头来看前言里面的那个问题,我们试想一下,如果我们在中间路由器上把每次TCP连接的最大MSS进行调整这样使得通过PPPoE链路的最大MSS值加上数据包头包尾不会超过PPPoE的MTU大小1492这样就不会造成无法通讯的问题。

所以上面的问题可以通过ip tcp adjust-mss 1452来解决(就是配置tcp mss的值为1452字节,这样即使有PPPoE的8字节,也不会超过1500字节)。

当然问题也可以通过修改PC机的MTU来解决。

路径MTU

从A到B可能经过不同的网络,其中最小的MTU就是路径MTU(以小的为准,要是超过了MTU就直接丢包**)**;
另外,从A到B,与B到A的寻路结果可能不同,所以它们的路径MTU也有可能不同

PMTU发现方式

PMTU:Path MTU Discovery:用于TCP/UDP数据包,通过设置初始数据包的DF=1不断试探最佳MTU值,最终发现端到端的最佳MTU值。

L2VPN的MTU协商

根据RFC 4447、RFC4761和RFC4762的定义,L2VPN(包括PWE3、VLL、VPLS)组网环境下,VC/PW建立过程中,需要协商MTU。如果两端MTU不一致,VC/PW无法建立

L2VPN类型 MTU协商值配置 MTU协商值的取值规则
PWE3 方式1:通过mpls l2vc或mpls switch-l2vc命令行中指定mtu参数
方式2:PW模板视图下配置mtu mtu-value命令
生效次序:
通过命令行指定的MTU参数值
PW模板的MTU配置值
AC接口配置的接口MTU值
如果以上3个参数都没配置,则MTU协商值缺省为1500字节。
Martini方式VLL mpls l2vc命令行中指定 生效次序:
通过命令行指定的MTU参数值
AC接口配置的接口MTU值
如果以上2个参数都没配置,则MTU协商值缺省为1500字节。
Kompella方式VLL MPLS-L2VPN实例视图下配置mtu mtu-value命令 MPLS-L2VPN实例视图下配置的MTU参数值优先生效。
如果MPLS-L2VPN实例视图下没配MTU,则MTU协商值缺省为1500字节。
VPLS VSI视图下配置mtu mtu-value命令 VSI视图下配置的MTU参数值优先生效。
如果VSI视图下没配MTU,则MTU协商值缺省为1500字节。

NE40E/80E/CX600/ME60产品缺省情况下,VC/PW建立过程中进行MTU协商。如果两端MTU不一致,VC/PW无法建立。但L2VPN MTU仅用于建立VC/PW,不影响报文转发。
缺省情况下,VPLS的MTU缺省值是1500字节,不受接口MTU的变更而变更,因为MTU在VSI视图配置。
部分设备制造商的设备不支持L2VPN的MTU匹配检查。为了和此类厂商设备互通,NE40E/80E/CX600/ME60产品上支持通过命令行,使设备在建立过程VC/PW忽略MTU匹配检查。
注:还有很多协议也都会协商MTU,但一般就是1500是OK的