我有一个连接到两个网络的服务器:
我想要设置一个Wireguard,使这两个网络可以从外部访问。我在配置中激活了ip转发(使用sysctl)。现在我需要设置一个NAT,以便通过两个本地网络从VPN服务器路由我的请求。我使用nftable来设置NAT。
我的问题是,对于只有一个接口的机器,我将使用以下配置:
table ip nat {
chain prerouting {
type nat hook prerouting priority 0;
}
chain postrouting {
type nat hook postrouting priority 100;
ip saddr 10.2.0.0/24 oifname eth0 masquerade
}
}但在这里,我不想通过eth0路由所有东西,我想具体地通过wlan0路由10.0.0.0/24的所有内容,通过eth0路由192.168.1.0/24的所有内容。如何使用nftable实现这一点?
发布于 2021-12-15 08:46:20
最后,我自己找到了答案,下面是如何做到的:您必须使用ip daddr参数根据目标地址进行筛选。我的最后一套规则如下:
table ip nat {
chain PREROUTING {
type nat hook prerouting priority filter; policy accept;
}
chain POSTROUTING {
type nat hook postrouting priority srcnat; policy accept;
ip saddr 10.2.0.0/24 ip daddr 192.168.0.0/16 oifname "eth0" masquerade
ip saddr 10.2.0.0/24 ip daddr 10.0.0.0/24 oifname "wlan0" masquerade
}
}这工作得很好。
https://serverfault.com/questions/1086271
复制相似问题