netfilter/iptables模块编译及应用

http://tech.ddvip.com   2006年04月03日    社区交流 收藏本文

本文详细介绍netfilter/iptables模块编译及应用

  make dep

  make modules SUBDIRS=net/ipv4/netfilter

  2.建立一个新目录备份原来模块,以防万一:

  mkdir /usr/src/netfilter

  cp /lib/modules/2.4.20-8/kernel/net/ipv4/netfilter/*.o /usr/src/netfilter/

  3.应用新的模块

  cp -f /usr/src/linux-2.4/net/ipv4/netfilter/*.o /lib/modules/2.4.20-8/kernel/net/ipv4/netfilter/

  4.更新你的modules.dep

  depmod -a

  当出现这个时,可以不用理会,因为ipchains, ipfwadm模块都没用,也可以把出错的删除.

  depmod: *** Unresolved symbols in /lib/modules/2.4.20-8/kernel/net/ipv4/netfilter/ipchains_core.o

  depmod: *** Unresolved symbols in /lib/modules/2.4.20-8/kernel/net/ipv4/netfilter/ipfwadm_core.o

  (四).编译安装新的iptables

  解压后有目录iptables-1.3.1

  cd /usr/src/iptables-1.3.1

  export KERNEL_DIR=/usr/src/linux-2.4

  export IPTABLES_DIR=/usr/src/iptables-1.3.1

  make BINDIR=/sbin LIBDIR=/lib MANDIR=/usr/share/man install

  三.安装完成,测试及应用

  1.内容过滤

  iptables -I FORWARD -m string --string "腾讯" -j DROP

  iptables -I FORWARD -s 192.168.3.159 -m string --string "qq.com" -j DROP

  iptables -I FORWARD -d 192.168.3.0/24 -m string --string "宽频影院" -j DROP

  iptables -I FORWARD -s 192.168.3.0/24 -m string --string "色情" -j DROP

  iptables -I FORWARD -p tcp --sport 80 -m string --string "广告" -j DROP

  2.备注应用

  iptables -I FORWARD -s 192.168.3.159 -p tcp --dport 80 -j DROP -m comment --comment "the bad guy can not online"

  iptables -I FORWARD -s 192.168.3.159 -m string --string "qq.com" -j DROP -m comment --comment "denny go to qq.com"

  3.并发连接应用

  iptables -I FORWARD -s 192.168.3.159 -p tcp --syn --dport 80 -m connlimit --connlimit-above 3 --connlimit-mask 24 -j DROP

  4.ip范围应用

  iptables -A FORWARD -m iprange --src-range 192.168.1.5-192.168.1.124 -j ACCEPT

  5.每隔N个匹配

  iptables -t mangle -A PREROUTING -m nth --every 10 -j DROP

  6.封杀BT类P2P软件

  iptables -A FORWARD -m ipp2p --edk --kazaa --bit -j DROP

  iptables -A FORWARD -p tcp -m ipp2p --ares -j DROP

  iptables -A FORWARD -p udp -m ipp2p --kazaa -j DROP

  7.配额匹配

  iptables -I FORWARD -s 192.168.3.159 -p tcp --dport 80 -m quota --quota 500 -j DROP

  iptables -I FORWARD -s 192.168.3.159 -p tcp --dport 80 -m quota --quota 500 -j ACCEPT

  以上均测试通过,只有geoip的geoipdb.bin没下载到,所以没测试

  在此仅为抛个砖头,更多的应用,要根据自己的需要来组合各个规则和模块了.

责编:豆豆技术应用

正在加载评论...