TCP MSS值分享

229阅读 0评论2012-03-09 wfeng
分类:系统运维

中低端 mss的实现原理为何经常要在内网口和外网口都要配置tcp mss 值呢

PC1(192.168.0.1)―――Router――――Internet―――-www server(238.135.1.1)

建立tcp连接的两端在三次握手时会协商tcp mss大小,具体如下:
pc1发出报文,其中option选项填充的mss字段一般为1460,同样www server收到syn报文后,会发送synack报文应答,option选项填充的mss字段也为1460;协商双方会比较synsyn+ack报文中mss字段大小,选择较小的mss作为发送tcp分片的大小。通过比较,协商双方的tcp mss都是1460

对于涉及mpls l3vpnpppoenatipsecl2tpgre等组网,通常由于报文太大需要分片,一般可以通过设置tcp mss解决。

针对上例说明tcp mss如何实现
1、
假设在路由器内网口配置tcp mss 1200
a)
路由器收到www serversynack报文时会修改option选项中的mss字段为1200,然后再转发给PC1PC1收到报文后认为对端的tcp mss1200这样PC1发送数据给www server时会以1200作为分片大小;但路由器修改tcp mss1200的操作www server是不知道的,因此www server还会以1460作为分片大小发送报文。

2、
假设再路由器外网口配置tcp mss 1200
a)
路由器收到PC1syn报文时会修改option选项中的mss字段为1200,然后再转发给www server 同样www server发送数据给PC1时会以1200作为分片大小;同样PC1不知道路由器修改tcp mss1200,因为PC1还会以1460作为分片大小发送报文。

3、
因此在实现双向大包传输时需要在内外网同时修改tcp mss

综上所述:在路由器接口上配置的tcp mss命令仅对出接口方向的syn报文和synack报文有效,对于入接口方向的synsynack报文无效。



CCIE Security 2009 IOS防火墙合集


上一篇:华为S8500交换机配置DHCP SERVER案例
下一篇:H3C的纯硬件三层交换机都有哪些系列号?