在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上编写运行C语言程序,经常会遇到程序崩溃、卡死等异...
git使用小结很多人可能和我一样,起初对git是一无所知的。我...
1. 操作系统环境、安装包准备 宿主机:Max OSX 10.10.5 虚拟...
因为业务系统需求,需要对web服务作nginx代理,在不断的尝试...
Linux模块机制浅析 Linux允许用户通过插入模块,实现干预内核...
一、Hadoop HA的Web页面访问 Hadoop开启HA后,会同时存在两个...