免费注册 查看新帖 |

Chinaunix

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

PPPoE 网关 Iptables MTU 怪问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2005-11-10 10:31 |只看该作者 |倒序浏览
Iptables网关MTU问题
  • 问题描述Iptables作SNAT网关时候, 发现一些PC机不能正常访问一些站点,表现为, 浏览器可以解析站点, 部分打开站点, 接着就超时了。
    • 原因
    ADSL的PPPoE连接的MTU是1492, 而Widows和Linux缺省的MTU是1500, 当浏览器相WEB服务器发送请求时, 要求MSS是1460, 一些站点屏蔽了ICMP3/4访问或者禁用了PMTUD协议而导致MSS值是1460, 当WEB服务器返回的包小于1452时,客户端可以正常接受数据, 超过1452时候无法得到数据。
    • 解决方法
    1。 使用ping找到你的MAX MTU Size
    ping -l mtu_size-28 -f your_gateway
    从1500开始,知道没有收到错误信息the Packet needs to be fragmented but DF set。 28是IP和ICMP协议所用的字节。一般而言PPPoE是1492。
    2。调整PC的MTU
    Windows 2000/XP
    注册表:HKEY_LOCAL_MACHINE SYSTEM CurrentControlSet Services
    TcpipParameters Interfaces, and (Edit -> New -> DWORD Value),
    and name the value MTU.
    Double-click the new value, choose the Decimal option, and type the MTU value determined above. 重启。
    Windows 98
    注册表: HKEY_LOCAL_MACHINE System CurrentControlSet Services ClassNet 增加MaxMTU string项,
    Linux
    ifconfig interface mtu mtu_size
    3. 调整网关
    Iptables
    增加规则:
    iptables -o  ppp_interface -I FORWARD 1 -p tcp --tcp-flags SYN,RST SYN -m tcpmss --mss 1400:1536 -j TCPMSS --clamp-mss-to-pmtu
    出站包大小改为pppx的MTU尺寸。
    或者 clamp mss size in pppoe
    RedHat修改/etc/sysconfig/networking-script/ifcfg-ppp0
    CLAMPMSS=1452
    Debian
    修改 /etc/ppp/peers/dsl-provider
    增加
    pty "/usr/sbin/pppoe -I eth1 -T 80 -m 1452
    注释掉 plugin, rp-pppoe.so 好像有bug
    Linksys 路由器

    参考:
    http://www.phildev.net/mss/index.html


    本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u/6566/showart_56229.html
  • 您需要登录后才可以回帖 登录 | 注册

    本版积分规则 发表回复

      

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

    清除 Cookies - ChinaUnix - Archiver - WAP - TOP