周海汉 /文
2010-3-25
http://blog.csdn.net/ablo_zhou
为了安全起见,web服务器,数据库,计费等有重要内容的机器,可能是藏在防火墙后面的,甚至没有外网地址。在此,我们假定需要给一台只有内网地址的web服务器设置linux网关,让外网可以访问web,但又屏蔽其他端口的访问。
iptables是linux 2.4以上内核自带的防火墙,可以用于阻挡非法的端口和IP访问,也可以用于做网关设备,配置NAT/防火墙,做port forward.
iptables 的逻辑,由表tables,链chains,规则rules组成。根据报文头进行相应的处理。系统接受到包时,底层路由根据目的地分发。如果目的地是本机,则进入INPUT链。本机处理完,再进入OUTPUT链,发送出去。如果目的地不是本机,则进入FORWARD链,符合规则,则转发出去。
设备设置:
web site ip port: 192.168.12.50 80 (windows IIS server or linux apache)
gateway public ip(eth0): 210.211.22.20, private ip(eth1): 192.168.12.10 (centos 5.2)
现在我们希望访问http://210.211.22.20 即可访问http://192.168.12.50:80.
1.gateway上设置允许IP转送:
vi /etc/sysctl.conf
设置:
net.ipv4.ip_forward = 1
执行
sysctl -p
应该看到
net.ipv4.ip_forward = 1
2.gateway上设置iptables
#nat表,PREROUTING链,设置对eth0的目标端口是80的tcp协议,放到DNAT,forward到192.168.12.50:80 iptables -A PREROUTING -t nat -i eth0 -p tcp --dport 80 -j DNAT --to 192.168.12.50:80 #filter表,对接到的eth0的,从eth1转到192.168.12.50:80 iptables -A FORWARD -p tcp -i eth0 -o eth1 -d 192.168.12.50 --dport 80 -j ACCEPT #但是,也要做nat变换,维护一份映射表,从eth1送出时采用内网地址,回来时变为公网地址。否则外网会收不到回复。 iptables -t nat -A POSTROUTING -j MASQUERADE -o eth1
设置完毕,执行service iptables save
此时,从外网访问http://210.211.22.20已经可以看到内网的网页。
3.举一反三,根据需要,可以将端口设置为数据库的1433或ftp的20,21,smtp和pop的25,110等,协议和转发需要稍有改动和调试。
例如,设置mssql数据库的代理。
#1.在nat表设置PREROUTING链,这里没有 -o选项。 iptables -t nat -A PREROUTING -p tcp -i eth0 --dport 1433 -j DNAT --to 192.168.12.123:1433 #2.设置filter表 iptables -A FORWARD -p tcp -i eth0 -o eth1 --dport 1433 -d 192.168.12.123 -j ACCEPT #3.nat变换,如果有了就可以不设置 iptables -t nat -A POSTROUTING -j MASQUERADE -o eth1
4.设置好iptables,将不允许的访问全部禁止。