在Linux上使用多个上行链路进行NAT

前端之家收集整理的这篇文章主要介绍了在Linux上使用多个上行链路进行NAT前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
目前,我在服务器上有3个NIC,1个连接到adsl调制解调器(eth0),另一个连接到光纤(ppp0),另一个连接到LAN(eth2).

我已经设置了所有接口,路由和规则,如此处所述(http://www.linux.org/PRIVOXY-FORCE/docs/ldp/howto/Adv-Routing-HOWTO/lartc.rpdb.multiple-links.html),它完美地工作.我可以毫无问题地从外部连接到两台主机,但我现在面临另一个问题……

我只能在我设置为主表上的默认路由的主机上执行NAT.例如,如果我使用这些规则:

iptables -t nat -A PREROUTING -i eth0 -p tcp --dport 80 -j DNAT --to-destination 192.168.1.2:8080
iptables -t nat -A PREROUTING -i ppp0 -p tcp --dport 80 -j DNAT --to-destination 192.168.1.2:8080

它的工作原理取决于默认路由.如果默认路由是通过eth0,则来自ppp0的传入连接不会重定向到LAN计算机.此外,如果默认路由是通过ppp0,则不会重定向来自eth0的连接.我为每个提供商提供了一个表,其中网关配置为默认路由,但它似乎不适用于NAT.

有没有人有想法解决这个问题?

解决方法

如果您已正确设置“ip route”路由,则“默认路由”无意义.
困难来自于eth0和ppp0都可能由DHCP设置,这将覆盖您设置的任何内容.

您应该为您已设置的所有表格提供“ip route show”的输出,以及“ip rule show”以及您在设置期间完成的任何其他操作.

顺便说一下,你发布的链接对我不起作用,this one does

猜你在找的Linux相关文章