现在看看iptables服务,你可以执行iptables -V看看是否iptables已经安装在系统里了(一般来说都会安装了),还可以显示你的版本号——我的是1.3.6版本。

ok,编辑脚本吧。输入

vi FWstart.sh进入编辑界面(下面是文本正文)

#!/bin/sh

#下面两项分别是启动linux的转发功能和防syn攻击的参数。

#没有第一条就不能实现linux的数据包转发

#意思就是把文件/proc/sys/net/ipv4/ip_forward的值设定为1

#第二条我不太了解,但还是加上吧。

  1. echo "1" > /proc/sys/net/ipv4/ip_forward  
  2.  
  3. echo "1" > /proc/sys/net/ipv4/tcp_syncookies  
  4.  

#加载iptables启动所需的各种模块,据说很多版本不加也可以,因为具体的参数引用实际上已经调

#用了它们,但是考虑兼容性加上也没什么,如果你去掉了这几行,结果出现了问题,不妨再加上。

  1. modprobe ip_tables  
  2.  
  3. modprobe ip_nat_ftp  
  4.  
  5. modprobe ip_nat_irc  
  6.  
  7. modprobe ip_conntrack  
  8.  
  9. modprobe ip_conntrack_ftp  
  10.  
  11. modprobe ip_conntrack_irc  
  12.  

#清空原有的iptables的表(主要是filter表和nat表)和表中的链

  1. /sbin/iptables -F  
  2.  
  3. /sbin/iptables -X  
  4.  
  5. /sbin/iptables -Z  
  6.  
  7. /sbin/iptables -F -t nat  
  8.  
  9. /sbin/iptables -X -t nat  
  10.  
  11. /sbin/iptables -Z -t nat  
  12.  

#设置filter表中三个链的默认规则,进入(INPUT)发出(OUTPUT)都是允许ACCEPT

#转发(FORWARD)是丢弃DROP,这样才能起到防火墙的作用。

#你也可以设定更细致的INPUT规则,实际上INPUT链是针对保护防火墙自身的,我不多说了,

#我的重点放在FORWARD链,它是负责过滤转发包的。

  1. /sbin/iptables -P INPUT ACCEPT  
  2.  
  3. /sbin/iptables -P OUTPUT ACCEPT  
  4.  
  5. /sbin/iptables -P FORWARD DROP  
  6.  

#现在给网卡添加ip地址,一块网卡上可以拥有很多IP地址,只有这样,外网访问1.1.1.2的时候

#才能重新定向到内网的192.168.1.1上去。

ip address add 1.1.1.2/30 brd + dev eth0

ip address add 1.1.1.3/30 brd + dev eth0

#设置允许对服务器192.168.1.1和192.168.1.2的访问,否则的话外网

#就无法把数据发送到这两台服务器上。当然你可以设置更多的规则,这实际上就是为这两台

#服务器设置的防火墙了。比如如果你想设置只允许访问1.1上的80端口,只要把

#/sbin/iptables -A FORWARD -d 192.168.1.1 -j ACCEPT改为

#/sbin/iptables -A FORWARD -d 192.168.1.1 --dport 80 -j ACCEPT就可以了,

#其他不要改,除非你明白修改后的含义。不过我要提醒你,按照这种设置,你的两台

#服务器基本上就是和单独接入在internet中没什么两样,只是进行了地址转换,

#多了一点点保护而已。建议你还是多学学iptables防火墙的其他内容。

  1. /sbin/iptables -A FORWARD -s 192.168.1.1 -j ACCEPT  
  2.  
  3. /sbin/iptables -A FORWARD -d 192.168.1.1 -j ACCEPT  
  4.  
  5. /sbin/iptables -A FORWARD -s 192.168.1.2 -j ACCEPT  
  6.  
  7. /sbin/iptables -A FORWARD -d 192.168.1.2 -j ACCEPT  
  8.  


相关内容