linux – 如何将所有流量转发/ NAT到一个接口/ IP到远程IP?

我有一个“服务器A”,它附加了多个IP,如下所示:
eth0:0 1.1.1.1
eth0:1 1.1.1.2
eth0:2 1.1.1.3

我有一个“服务器B”,它还附加了多个IP,如下所示:

eth0:0 2.2.2.1
eth0:1 2.2.2.2
eth0:2 2.2.2.3

现在,我想在“服务器A”上设置iptables,以便将“eth0:2”上的所有流量转发/ NAT转移到“服务器B”上的IP 2.2.2.3.

我已经验证“服务器A”能够在IP 2.2.2.3上与“服务器B”“对话”. Ping和telnet打开端口工作正常,我打开了forward-flag(net.ipv4.ip_forward = 1)

我尝试了多种不同的方式,DNAT,SNAT,MASQUERADE等,但我无法获得任何工作.

如果我尝试在SAME服务器上的IP之间转发流量,则此行正常工作:

iptables -t nat -A PREROUTING -d 1.1.1.3 -j DNAT --to-destination 1.1.1.2

但如果我为“2.2.2.3”切换出“1.1.1.2”,它就不起作用了.

我假设我需要第二个iptable规则来解决它.我尝试了以下POSTROUTING规则,没有任何运气(不是同时):

iptables -t nat -A POSTROUTING -d 2.2.2.3 -j MASQUERADE
iptables -t nat -A POSTROUTING -d 2.2.2.3 -j SNAT --to 1.1.1.3
iptables -t nat -A POSTROUTING -j MASQUERADE

我错过了什么?

编辑1:

我终于通过使用以下方式使其工作:

net.bridge.bridge-nf-call-iptables=0

iptables -t nat -A PREROUTING -d 1.1.1.3 -j DNAT --to-destination 2.2.2.3
iptables -t nat -A POSTROUTING -d 2.2.2.3 -j SNAT --to 1.1.1.3

但是,现在出现了另一个问题.服务器2.2.2.3上的所有日志等显示所有流量现在来自1.1.1.3,如apache日志,邮件日志等.我认为这是NAT的本质.

但是,当我在家用路由器上执行标准端口转发到运行apache的笔记本电脑时,我在日志中看到原来的“请求者IP”.那么,路由器如何做到这一点?我怎么能在我的服务器设置上做同样的事情?

最重要的是,我想将所有流量从服务器A(1.1.1.3)转发到服务器B(2.2.2.3),但我也希望能够看到流量来自服务器B(2.2.2.3)的位置,即apache日志应该显示请求者的原始IP.

我假设我应该使用除NAT之外的其他方式来实现这一点,它应该是可能的,因为即使我的简单家庭路由器也能够做到这一点.

另外一件事,连接到服务器A和服务器B的IP被锁定到每个相应的服务器.因此,服务器A无法从IP 2.2.2.3发送流量.它由我的提供商在路由器中锁定.

解决方法

对你修改过的问题的简短回答是,有两种方法可以做到这一点;两者都要求你删除第二个NAT步骤(它会破坏你正在寻找的信息).这样做之后的选择是:

1)使服务器A成为服务器B的下一跳,用于所讨论的流量,这就是为什么它适用于您提到的路由器.这可以通过使服务器A成为服务器B的认路由,或使用policy routing,或使用some fancy iptables,或使用某种隧道,以cludgeyness的顺序完成.

2)“手动”在服务器B上反转服务器A的NAT,导致不对称的流量(通常不鼓励).像iptables -t nat -I POSTROUTING -j SNAT -s 2.2.2.3 – 到1.1.1.3之类的东西

我对选项(1)有100%的信心.我对(2)有90%的信心.

要理解这一点,您需要了解流量.

>客户端X将数据包发送到1.1.1.3.
>服务器A将该数据包的目的地NAT路由到2.2.2.3预路由,然后将流量路由到2.2.2.3,然后将该数据包的源NAT路由到路由后的1.1.1.3,然后将数据包发送到服务器B.
>服务器B在2.2.2.3上接收数据包,并在第二个NAT步骤中看到源地址1.1.1.3.它处理数据包并将回复发送回其源(1.1.1.3).
>服务器A在1.1.1.3上接收数据包,反转源NAT,路由数据包,反转目标NAT,并将数据包发送回客户端X.
>客户端X收到1.1.1.3的响应

现在让我们想象如果你没有第二个NAT会发生什么:

>客户端X将数据包发送到1.1.1.3.
>服务器A将该数据包的目的地NAT路由到2.2.2.3预路由,但在将数据包发送到服务器B时将源地址保留为X.
>服务器B在2.2.2.3上接收数据包,并看到X的源地址.它处理数据包并将回复发送回其源X.
>客户端X收到来自2.2.2.3的响应并丢弃它,因为它不知道来自Adam的2.2.2.3!

为了使客户端X能够理解数据包,它需要使用与原始数据包的目标相同的源地址到达客户端X.

发生这种情况的正常方法是服务器B有机会反转预路由NAT.要实现这一点,您需要在稍后的日期返回数据包.目前,您可以通过更改数据包的源地址来实现此目的,但这会破坏您在修订后的问题中要求的信息.

所以你的答案的第一步是,你不能做第二个NAT步骤(路由后SNAT):在服务器A上运行iptables -t nat -D POSTROUTING -j SNAT – 到1.1.1.3.

现在,您将面临逆转第一个NAT步骤的挑战.

如果服务器B要这样做,则需要服务器B来接收数据包.

>如果服务器A在与服务器B相同的LAN上具有地址C,则相对容易.在服务器B上:ip route通过C替换default,或者ip route add认通过C表a; ip规则从2.2.2.3表中添加a.
>否则你必须做一些喜欢隧道的事情.

但是,如果服务器B位置的路由器不是特别复杂(有状态地检查数据包并拒绝那些对于已知流量流没有正确顺序的数据包),那么你有一个更简单,如果超级丑陋的选项:反转NAT在服务器B上根据你对服务器A所做的事情的了解:在服务器B上iptables -t nat -I POSTROUTING -j SNAT -s 2.2.2.3 – 到1.1.1.3应该这样做的建议例子.这将使A和B上的Linux连接跟踪系统有点混乱(服务器将无法将返回流量与传入流量相关联,因此它们的连接跟踪将使连接保持在UNREPLIED状态)但它应该可以正常工作到大多数流量到数百个兆.

在这种情况下,最后一次穿过交通流量:

>客户端X将数据包发送到1.1.1.3.>服务器A将该数据包的目的地NAT路由到2.2.2.3预路由,但在将数据包发送到服务器B时将源地址保留为X.>服务器B在2.2.2.3上接收数据包,并看到X的源地址.它处理数据包并将回复路由回其源X,但在发送之前,源地址的路由后NAT是1.1. 1.3.>客户X收到声称来自1.1.1.3的回复并且很高兴.

相关文章

1、安装Apache。 1)执行如下命令,安装Apache服务及其扩展包...
一、先说一下用ansible批量采集机器信息的实现办法: 1、先把...
安装配置 1. 安装vsftpd 检查是否安装了vsftpd # rpm -qa | ...
如何抑制stable_secret读取关键的“net.ipv6.conf.all.stabl...
1 删除0字节文件 find -type f -size 0 -exec rm -rf {} ...
## 步骤 1:安装必要的软件包 首先,需要确保系统已安装 `dh...