V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
cwbsw
V2EX  ›  路由器

为什么无法用这样的规则实现 FullCone NAT?

  •  
  •   cwbsw · 2020-05-07 18:25:38 +08:00 · 2335 次点击
    这是一个创建于 1661 天前的主题,其中的信息可能已经有所发展或是发生改变。
    iptables -t nat -I POSTROUTING -o pppoe-wan -s 192.168.1.78 -p udp -j MASQUERADE --to-ports 50000-60000
    iptables -t nat -I PREROUTING -i pppoe-wan -p udp --dport 50000:60000 -j DNAT --to-destination 192.168.1.78
    

    尝试用如上规则使同一路由器后的不同设备获得 FullCone NAT,但结果并不成功,问题出在哪里呢?

    第 1 条附言  ·  2020-05-07 22:04:41 +08:00
    好吧,已经想明白了,自己犯蠢了。

    Linux 的 NAT 是基于 conntrack 的,按照上面的规则,internal_address:internal_port 会被映射到 WAN 侧的 external_address:external_port,别的主机发到 external_address:external_port 的包,会被转发给 internal_address:external_port,于是结果就是 symmetric NAT,DMZ 的做法能够 FullCone NAT 是因为映射过程中 port 没有改变。
    1 条回复    2020-05-09 20:01:50 +08:00
    CheekiBreeki
        1
    CheekiBreeki  
       2020-05-09 20:01:50 +08:00 via Android
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1237 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 18:10 · PVG 02:10 · LAX 10:10 · JFK 13:10
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.