iptables 实现端口映射

学习积累

[@more@]

环境:
客户端IP:1.2.3.4
网关
#eth0 外网 220.101.222.46(此地址为防火墙上填的外网地址)
192.168.123.123(此地址为防火墙映射到网关ETH0上的地址)
#eth1 内网 192.168.101.67

内网数据库
#192.168.101.66:1521

要实现这些功能,只要在iptables列表运行以下语句:
echo 1 > /proc/sys/net/ipv4/ip_forward
iptables -t nat -A PREROUTING -i eth0 -p tcp -d 192.168.123.123 --dport 1521 -j DNAT --to 192.168.101.66
iptables -A FORWARD -p tcp -d 192.168.101.66 --dport 1521 -j ACCEPT
iptables -t nat -A POSTROUTING -d 192.168.101.66 -p tcp --dport 1521 -j SNAT --to 192.168.123.123


在这里对上面几条的作用解释一下:
echo 1 > /proc/sys/net/ipv4/ip_forward
这一句,要使FORWARD能转发成功,就必须写.

iptables -t nat -A PREROUTING -i eth0 -p tcp -d 192.168.123.123 --dport 1521 -j DNAT --to 192.168.101.66
是把发送到192.168.123.123的1521数据都转发到192.168.101.66

iptables -A FORWARD -p tcp -d 192.168.101.66 --dport 1521 -j ACCEPT
要想把数据转发到101.66,还得允许转发这个包.

接下来的问题是,数据顺利到达了101.66,但数据没有能正常返回,因为到达101.66的源地址是1.2.3.4,而101.66是没法直接与1.2.3.4进行通信的.
所以需要把这条连接的源地址也改一改.
iptables -t nat -A POSTROUTING -d 192.168.101.66 -p tcp --dport 1521 -j SNAT --to 192.168.123.123

这样,数据就能正常通信了.

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/703656/viewspace-978530/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/703656/viewspace-978530/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值