亲测可用,iptables实现NAT转发。

2019-03-15 10:33:49 浏览数 (5)

环境

服务器A:192.168.1.7 服务器B: 192.168.1.160

需求

实现将本机(192.168.1.7:7410)端口流量转发给(192.168.1.160:9200)。

1. 内核允许IP转发

代码语言:javascript复制
echo 1 > /proc/sys/net/ipv4/ip_forward

2. 加载内核模块

代码语言:javascript复制
modprobe ip_conntrack

3. 设置filter表基础策略:允许入包/出包/转发(可进一步细化)

代码语言:javascript复制
iptables -P INPUT ACCEPT
iptables -P OUTPUT ACCEPT
iptables -P FORWARD ACCEPT

4. 设置基础会话规则

代码语言:javascript复制
iptables -A FORWARD -m state --state RELATED,ESTABLISHED -j ACCEPT

5. 端口转发流量

代码语言:javascript复制
iptables -t nat -A PREROUTING -d 192.168.1.7/32 -p tcp --dport 7410 -j DNAT --to-destination 192.168.1.160:9200;
iptables -t nat -A POSTROUTING -d 192.168.1.160/32 -p tcp --dport 9200 -j SNAT --to-source 192.168.1.7;

6.保存

代码语言:javascript复制
service iptables save
service iptables restart

7. 测试

代码语言:javascript复制
telnet 192.168.1.7:7410 

其他

代码语言:javascript复制
### 停止
service iptables stop
### 查看状态
service iptables status
### 备份
iptables-save > ables.bak
### 还原
iptables-restore < iptables.bak
nat

0 人点赞