<?xml version="1.0" encoding="UTF-8" ?>
<rss version="2.0">
<channel>
<title><![CDATA[沧海一粟]]></title> 
<link>http://www.dzhope.com/index.php</link> 
<description><![CDATA[Web系统架构与服务器运维,php开发]]></description> 
<language>zh-cn</language> 
<copyright><![CDATA[沧海一粟]]></copyright>
<item>
<link>http://www.dzhope.com/post//</link>
<title><![CDATA[Linux的iptables常用配置范例（1）]]></title> 
<author>jed &lt;jed521@163.com&gt;</author>
<category><![CDATA[服务器技术]]></category>
<pubDate>Fri, 01 Apr 2011 17:02:17 +0000</pubDate> 
<guid>http://www.dzhope.com/post//</guid> 
<description>
<![CDATA[ 
	以下是来自 <a href="http://wiki.ubuntu.org.cn/IptablesHowTo" target="_blank">http://wiki.ubuntu.org.cn/IptablesHowTo</a> 上的配置说明<br/><br/>可以通过/sbin/iptables -F清除所有规则来暂时停止防火墙： (警告：这只适合在没有配置防火墙的环境中，如果已经配置过默认规则为deny的环境，此步骤将使系统的所有网络访问中断)<br/><br/>如果想清空的话，先执行<br/>/sbin/iptables -P INPUT ACCEPT<br/>然后执行<br/>/sbin/iptables -F<br/>通过iptables -L 看到如下信息<br/>Chain INPUT (policy DROP 0 packets, 0 bytes) （注意 是DROP）<br/>执行/sbin/iptables -F就肯定立马断开连接<br/>当执行了<br/>/sbin/iptables -P INPUT ACCEPT<br/>再次通过iptables -L看信息的话就是<br/>Chain FORWARD (policy ACCEPT 0 packets, 0 bytes)<br/>所以现在是可以安全使用<br/>/sbin/iptables -F了<br/><br/>——————————————————————<br/><br/>常用的IPTABLES规则如下：<br/>只能收发邮件，别的都关闭<br/>iptables -I Filter -m mac –mac-source 00:0F:EA:25:51:37 -j DROP<br/>iptables -I Filter -m mac –mac-source 00:0F:EA:25:51:37 -p udp --dport 53 -j ACCEPT<br/>iptables -I Filter -m mac –mac-source 00:0F:EA:25:51:37 -p tcp --dport 25 -j ACCEPT<br/>iptables -I Filter -m mac –mac-source 00:0F:EA:25:51:37 -p tcp --dport 110 -j ACCEPT<br/><br/>IPSEC NAT 策略<br/>iptables -I PFWanPriv -d 192.168.100.2 -j ACCEPT<br/>iptables -t nat -A PREROUTING -p tcp --dport 80 -d $INTERNET_ADDR -j DNAT –to-destination 192.168.100.2:80<br/>iptables -t nat -A PREROUTING -p tcp --dport 1723 -d $INTERNET_ADDR -j DNAT –to-destination 192.168.100.2:1723<br/>iptables -t nat -A PREROUTING -p udp --dport 1723 -d $INTERNET_ADDR -j DNAT –to-destination 192.168.100.2:1723<br/>iptables -t nat -A PREROUTING -p udp --dport 500 -d $INTERNET_ADDR -j DNAT –to-destination 192.168.100.2:500<br/>iptables -t nat -A PREROUTING -p udp --dport 4500 -d $INTERNET_ADDR -j DNAT –to-destination 192.168.100.2:4500<br/><br/>FTP服务器的NAT<br/>iptables -I PFWanPriv -p tcp --dport 21 -d 192.168.100.200 -j ACCEPT<br/>iptables -t nat -A PREROUTING -p tcp --dport 21 -d $INTERNET_ADDR -j DNAT –to-destination 192.168.100.200:21<br/><br/>只允许访问指定网址<br/>iptables -A Filter -p udp --dport 53 -j ACCEPT<br/>iptables -A Filter -p tcp --dport 53 -j ACCEPT<br/>iptables -A Filter -d <a href="http://www.3322.org" target="_blank">www.3322.org</a> -j ACCEPT<br/>iptables -A Filter -d img.cn99.com -j ACCEPT<br/>iptables -A Filter -j DROP<br/><br/>开放一个IP的一些端口，其它都封闭<br/>iptables -A Filter -p tcp --dport 80 -s 192.168.100.200 -d <a href="http://www.pconline.com.cn" target="_blank">www.pconline.com.cn</a> -j ACCEPT<br/>iptables -A Filter -p tcp --dport 25 -s 192.168.100.200 -j ACCEPT<br/>iptables -A Filter -p tcp --dport 109 -s 192.168.100.200 -j ACCEPT<br/>iptables -A Filter -p tcp --dport 110 -s 192.168.100.200 -j ACCEPT<br/>iptables -A Filter -p tcp --dport 53 -j ACCEPT<br/>iptables -A Filter -p udp --dport 53 -j ACCEPT<br/>iptables -A Filter -j DROP<br/><br/>多个端口<br/>iptables -A Filter -p tcp -m multiport –destination-port 22,53,80,110 -s 192.168.20.3 -j REJECT<br/><br/>连续端口<br/>iptables -A Filter -p tcp -m multiport –source-port 22,53,80,110 -s 192.168.20.3 -j REJECT iptables -A Filter -p tcp –source-port 2:80 -s 192.168.20.3 -j REJECT<br/><br/>指定时间上网<br/>iptables -A Filter -s 10.10.10.253 -m time –timestart 6:00 –timestop 11:00 –days Mon,Tue,Wed,Thu,Fri,Sat,Sun -j DROP<br/>iptables -A Filter -m time –timestart 12:00 –timestop 13:00 –days Mon,Tue,Wed,Thu,Fri,Sat,Sun -j ACCEPT<br/>iptables -A Filter -m time –timestart 17:30 –timestop 8:30 –days Mon,Tue,Wed,Thu,Fri,Sat,Sun -j ACCEPT<br/>禁止多个端口服务<br/>iptables -A Filter -m multiport -p tcp --dport 21,23,80 -j ACCEPT<br/><br/>将WAN 口NAT到PC<br/>iptables -t nat -A PREROUTING -i $INTERNET_IF -d $INTERNET_ADDR -j DNAT –to-destination 192.168.0.1<br/><br/>将WAN口8000端口NAT到192。168。100。200的80端口<br/>iptables -t nat -A PREROUTING -p tcp --dport 8000 -d $INTERNET_ADDR -j DNAT –to-destination 192.168.100.200:80<br/><br/>MAIL服务器要转的端口<br/>iptables -t nat -A PREROUTING -p tcp --dport 110 -d $INTERNET_ADDR -j DNAT –to-destination 192.168.100.200:110<br/>iptables -t nat -A PREROUTING -p tcp --dport 25 -d $INTERNET_ADDR -j DNAT –to-destination 192.168.100.200:25<br/><br/>只允许PING 202。96。134。133,别的服务都禁止<br/>iptables -A Filter -p icmp -s 192.168.100.200 -d 202.96.134.133 -j ACCEPT<br/>iptables -A Filter -j DROP<br/>禁用BT配置<br/>iptables –A Filter –p tcp --dport 6000:20000 –j DROP<br/>禁用QQ防火墙配置<br/>iptables -A Filter -p udp --dport ! 53 -j DROP<br/>iptables -A Filter -d 218.17.209.0/24 -j DROP<br/>iptables -A Filter -d 218.18.95.0/24 -j DROP<br/>iptables -A Filter -d 219.133.40.177 -j DROP<br/>基于MAC，只能收发邮件，其它都拒绝<br/>iptables -I Filter -m mac –mac-source 00:0A:EB:97:79:A1 -j DROP<br/>iptables -I Filter -m mac –mac-source 00:0A:EB:97:79:A1 -p tcp --dport 25 -j ACCEPT<br/>iptables -I Filter -m mac –mac-source 00:0A:EB:97:79:A1 -p tcp --dport 110 -j ACCEPT<br/>禁用MSN配置<br/>iptables -A Filter -p udp --dport 9 -j DROP<br/>iptables -A Filter -p tcp --dport 1863 -j DROP<br/>iptables -A Filter -p tcp --dport 80 -d 207.68.178.238 -j DROP<br/>iptables -A Filter -p tcp --dport 80 -d 207.46.110.0/24 -j DROP<br/>只允许PING 202。96。134。133 其它公网IP都不许PING<br/>iptables -A Filter -p icmp -s 192.168.100.200 -d 202.96.134.133 -j ACCEPT<br/>iptables -A Filter -p icmp -j DROP<br/>禁止某个MAC地址访问internet:<br/>iptables -I Filter -m mac –mac-source 00:20:18:8F:72:F8 -j DROP<br/>禁止某个IP地址的PING:<br/>iptables –A Filter –p icmp –s 192.168.0.1 –j DROP<br/>禁止某个IP地址服务：<br/>iptables –A Filter -p tcp -s 192.168.0.1 --dport 80 -j DROP<br/>iptables –A Filter -p udp -s 192.168.0.1 --dport 53 -j DROP<br/>只允许某些服务，其他都拒绝(2条规则)<br/>iptables -A Filter -p tcp -s 192.168.0.1 --dport 1000 -j ACCEPT<br/>iptables -A Filter -j DROP<br/>禁止某个IP地址的某个端口服务<br/>iptables -A Filter -p tcp -s 10.10.10.253 --dport 80 -j ACCEPT<br/>iptables -A Filter -p tcp -s 10.10.10.253 --dport 80 -j DROP<br/>禁止某个MAC地址的某个端口服务<br/>iptables -I Filter -p tcp -m mac –mac-source 00:20:18:8F:72:F8 --dport 80 -j DROP<br/>禁止某个MAC地址访问internet:<br/>iptables -I Filter -m mac –mac-source 00:11:22:33:44:55 -j DROP<br/>禁止某个IP地址的PING:<br/>iptables –A Filter –p icmp –s 192.168.0.1 –j DROP<br/>————————————————————————————————<br/><br/><br/>IPFW 或 Netfilter 的封包流向，local process 不会经过 FORWARD Chain，<br/>因此 lo 只在 INPUT 及 OUTPUT 二个 chain 作用。<br/>样例1：<br/><br/>#!/bin/sh<br/>#<br/># 静态安全防火墙脚本<br/>#<br/># created by yejr,2007-03-20<br/>#<br/>#<br/>#定义信任IP列表<br/>#内部ip子网<br/>MY_IP_LIST_1=192.168.8.0/24<br/>#外部ip子网<br/>MY_IP_LIST_2=1.2.3.0/24<br/>#所有<br/>ALL_IP=0/0<br/>#北京ADSL动态IP列表<br/>BJADSL_IP_LIST=221.218.0.0/16<br/>#定义端口列表<br/>#涉及ftp端口<br/>FTP_PORT_1=20<br/>FTP_PORT_RANGE=”1023:65535″<br/>FTP_PORT_2=21<br/>#dns端口<br/>DNS_PORT=53<br/>#httpd端口<br/>HTTP_PORT=80<br/>#ssh 端口<br/>SSH_PORT=4321<br/>IPT=”/sbin/iptables”<br/># 内网<br/>LC_IFACE=”eth1″<br/>LC_ADDR=”192.168.8.2″<br/># 公网<br/>INET_IFACE=”eth0″<br/>INET_ADDR=”1.2.3.4″<br/># 本机<br/>LO_IFACE=”lo”<br/>LO_ADDR=127.0.0.1<br/># 定义接受请求速率限制<br/>MAX_NUM_PACKS=1024<br/># 核心模块<br/>/sbin/modprobe ip_tables<br/># ftp模块<br/>/sbin/modprobe ip_nat_ftp<br/># 限速模块<br/>/sbin/modprobe ip_conntrack<br/># 重新设置防火墙到默认状态<br/>$IPT -P INPUT ACCEPT<br/>$IPT -P FORWARD ACCEPT<br/>#$IPT -P OUTPUT ACCEPT<br/>$IPT -F<br/>$IPT -X<br/># 先拒绝所有请求<br/>$IPT -P INPUT DROP<br/>#$IPT -P OUTPUT DROP<br/>$IPT -P FORWARD DROP<br/>##########################################<br/># 设定一些内核参数<br/>##########################################<br/>#启动 SYN 泛洪保护<br/>echo ”1″ > /proc/sys/net/ipv4/tcp_syncookies<br/>#启用反向路径源认证,防止欺骗<br/>echo ”1″ > /proc/sys/net/ipv4/conf/all/rp_filter<br/>#关闭 icom echo 广播包请求<br/>echo ”1″ > /proc/sys/net/ipv4/icmp_echo_ignore_broadcasts<br/>#拒绝源路由包<br/>echo ”0″ > /proc/sys/net/ipv4/conf/all/accept_source_route<br/>#仅仅接收发给默认网关列表中网关的ICMP重定向消息<br/>echo ”1″ > /proc/sys/net/ipv4/conf/all/secure_redirects<br/>#记录来自非法ip的请求<br/>echo ”1″ > /proc/sys/net/ipv4/conf/all/log_martians<br/>##########################################<br/># 建立规则<br/>##########################################<br/># 无效请求包规则<br/>$IPT -N bad_packets<br/># 另一个恶意 TCP 包规则<br/>$IPT -N bad_tcp_packets<br/># ICMP规则(进/出)<br/>$IPT -N icmp_packets<br/># 来自公网的UDP请求规则<br/>$IPT -N inet_udp_inbound<br/># 从本机发往公网的UDP请求规则,默认全部允许<br/>$IPT -N udp_outbound<br/># 来自公网的 TCP 请求规则<br/>$IPT -N inet_tcp_inbound<br/># 从本机发往公网的 TCP 请求规则,默认全部允许<br/>$IPT -N tcp_outbound<br/>##########################################<br/># 恶意请求规则<br/>##########################################<br/># 立刻断掉非法的包并且记录<br/>$IPT -A bad_packets -p ALL -m state --state INVALID <br/>-j LOG –log-prefix ”IPTABLES_INVALID_PACKET:”<br/>$IPT -A bad_packets -p ALL -m state --state INVALID <br/>-j DROP<br/># 再次检查 TCP 包是否还有问题<br/>$IPT -A bad_packets -p tcp -j bad_tcp_packets<br/># 都正确了,返回<br/>$IPT -A bad_packets -p ALL -j RETURN<br/>##########################################<br/># 恶意 TCP 请求<br/>##########################################<br/>#<br/># 所有的 TCP 请求都必须经过以下规则过滤. 任何新请求都<br/># 必须以一个 sync 包开始.<br/># 如果不是这样的话,很可能表示这是一个扫描动作,这些有<br/># NEW 状态的包会被丢弃<br/>#<br/>$IPT -A bad_tcp_packets -p tcp ! –syn -m state --state <br/>NEW -j LOG –log-prefix ”IPTABLES_NEW_NOT_SYN:”<br/>$IPT -A bad_tcp_packets -p tcp ! –syn -m state --state <br/>NEW -j DROP<br/>$IPT -A bad_tcp_packets -p tcp –tcp-flags ALL NONE -j <br/>LOG –log-prefix ”IPTABLES_STEALTH_SCAN:”<br/>$IPT -A bad_tcp_packets -p tcp –tcp-flags ALL NONE -j DROP<br/>$IPT -A bad_tcp_packets -p tcp –tcp-flags ALL ALL -j <br/>LOG –log-prefix ”IPTABLES_STEALTH_SCAN:”<br/>$IPT -A bad_tcp_packets -p tcp –tcp-flags ALL ALL -j DROP<br/>$IPT -A bad_tcp_packets -p tcp –tcp-flags ALL FIN,URG,PSH<br/>-j LOG –log-prefix ”IPTABLES_STEALTH_SCAN:”<br/>$IPT -A bad_tcp_packets -p tcp –tcp-flags ALL FIN,URG,PSH<br/>-j DROP<br/>$IPT -A bad_tcp_packets -p tcp –tcp-flags ALL SYN,RST,ACK,FIN,URG <br/>-j LOG –log-prefix ”IPTABLES_STEALTH SCAN:”<br/>$IPT -A bad_tcp_packets -p tcp –tcp-flags ALL <br/>SYN,RST,ACK,FIN,URG -j DROP<br/>$IPT -A bad_tcp_packets -p tcp –tcp-flags <br/>SYN,RST SYN,RST -j LOG –log-prefix <br/>“IPTABLES_STEALTH SCAN:”<br/>$IPT -A bad_tcp_packets -p tcp –tcp-flags <br/>SYN,RST SYN,RST -j DROP<br/>$IPT -A bad_tcp_packets -p tcp –tcp-flags <br/>SYN,FIN SYN,FIN -j LOG –log-prefix <br/>“IPTABLES_STEALTH SCAN:”<br/>$IPT -A bad_tcp_packets -p tcp –tcp-flags SYN,FIN SYN,FIN -j DROP<br/># 都没问题了,返回<br/>$IPT -A bad_tcp_packets -p tcp -j RETURN<br/>##########################################<br/># ICMP 包规则<br/>##########################################<br/>#<br/># ICMP 包必须封装在一个2层的帧中,因此它们不会有碎片.<br/># 带有碎片的 ICMP 包通常被<br/># 标记为恶意攻击<br/>#<br/>$IPT -A icmp_packets –fragment -p ICMP -j LOG <br/>–log-prefix ”IPTABLES_ICMP Fragment:”<br/>$IPT -A icmp_packets –fragment -p ICMP -j DROP<br/>#<br/># 默认地,所有丢弃的 ICMP 包都不记录日志. ”冲击波”<br/># 以及 ”蠕虫” 会导致系统发起大量<br/># ping 请求. 如果想要记录 icmp log 就不要把本行注释掉<br/>#<br/># 允许自有服务器ip及北京地区adsl ip进行 PING<br/>$IPT -A icmp_packets -p ICMP -s $MY_IP_LIST_2 -j ACCEPT<br/>$IPT -A icmp_packets -p ICMP -s $BJADSL_IP_LIST -j ACCEPT<br/># 拒掉其他 PING<br/>$IPT -A icmp_packets -p ICMP -s 0/0 –icmp-type 8 -j DROP<br/># 接受超时 icmp 包<br/>$IPT -A icmp_packets -p ICMP -s 0/0 –icmp-type 11 -j ACCEPT<br/>##########################################<br/># TCP & UDP 包规则<br/>##########################################<br/>##########################################<br/># 来自公网的 UDP 请求<br/>##########################################<br/>#$IPT -A inet_udp_inbound -p UDP <br/>-s $MY_IP_LIST_2 --dport $DNS_PORT -j ACCEPT<br/># 都没问题了,返回<br/>$IPT -A inet_udp_inbound -p UDP -j RETURN<br/>##########################################<br/># 发往公网的 UDP 请求<br/>##########################################<br/># 都没问题了,返回<br/>$IPT -A udp_outbound -p UDP -s 0/0 -j ACCEPT<br/>##########################################<br/># 来自公网的 TCP 请求<br/>##########################################<br/># sshd 只对 北京ADSL IP段开放<br/>$IPT -A inet_tcp_inbound -p TCP <br/>-s $BJADSL_IP_LIST --dport $SSH_PORT -j ACCEPT<br/># 允许自有服务器 IP 的 FTP 端口请求<br/># FTP Data fix<br/>$IPT -A inet_tcp_inbound -p TCP -s $MY_IP_LIST_2 <br/>–sport $FTP_PORT_1 --dport $FTP_PORT_RANGE ! –syn <br/>-m state --state RELATED -j ACCEPT<br/>$IPT -A inet_tcp_inbound -p TCP -s $MY_IP_LIST_2 <br/>-m state --state ESTABLISHED -j ACCEPT<br/>$IPT -A inet_tcp_inbound -p UDP -s $MY_IP_LIST_2 <br/>--dport $FTP_PORT_RANGE -j ACCEPT<br/>$IPT -A inet_tcp_inbound -p TCP -s $MY_IP_LIST_2 <br/>--dport $FTP_PORT_1 ! –syn -j ACCEPT<br/>$IPT -A inet_tcp_inbound -p TCP -s $MY_IP_LIST_2 <br/>--dport $FTP_PORT_2 -j ACCEPT<br/>#允许所有ip访问 http 服务<br/>$IPT -A inet_tcp_inbound -p TCP -s $ALL_IP <br/>--dport $HTTP_PORT -j ACCEPT<br/># 都没问题了,返回<br/>$IPT -A inet_tcp_inbound -p TCP -j RETURN<br/>##########################################<br/># 发往公网的 TCP 请求<br/>##########################################<br/># 都没问题了,返回<br/>$IPT -A tcp_outbound -p TCP -s 0/0 -j ACCEPT<br/>##########################################<br/># 其他收到的请求<br/>##########################################<br/># 允许本机及本子网间的任何通信<br/>$IPT -A INPUT -p ALL -i $LO_IFACE -j ACCEPT<br/>$IPT -A INPUT -p ALL -d $LC_ADDR -j ACCEPT<br/># 来自信任ip的任何请求都接受<br/>$IPT -A INPUT -p ALL -s $MY_IP_LIST_1 -j ACCEPT<br/>$IPT -A INPUT -p ALL -s $MY_IP_LIST_2 -j ACCEPT<br/># 丢弃任何错误包<br/>$IPT -A INPUT -p ALL -j bad_packets<br/># 拒掉 DOCSIS 请求<br/>$IPT -A INPUT -p ALL -d 224.0.0.1 -j REJECT<br/># 接受 Established 连接<br/>$IPT -A INPUT -p ALL -i $INET_IFACE -m state <br/>--state ESTABLISHED,RELATED -j ACCEPT<br/># 定义上面的几条路由规则<br/>$IPT -A INPUT -p TCP -d $INET_ADDR -j inet_tcp_inbound<br/>$IPT -A INPUT -p UDP -d $INET_ADDR -j inet_udp_inbound<br/>$IPT -A INPUT -p ICMP -d $INET_ADDR -j icmp_packets<br/># 丢弃且不记录广播包<br/>$IPT -A INPUT -m pkttype –pkt-type broadcast -j REJECT<br/># 记录其他未匹配到的包<br/>$IPT -A INPUT -m limit –limit $MAX_NUM_PACKS/minute <br/>–limit-burst $MAX_NUM_PACKS -j LOG –log-prefix <br/>“IPTABLES_MISS_MATCH_INPUT:”<br/>##########################################<br/># 其他发出的请求<br/>##########################################<br/># 无论如何都丢弃错误的 ICMP 包,防止溢出<br/>$IPT -A OUTPUT -m state -p icmp --state INVALID <br/>-j REJECT<br/># 允许对外的任何请求<br/>$IPT -A OUTPUT -p ALL -s $ALL_IP -j ACCEPT<br/># 记录其他未匹配到的包<br/>$IPT -A OUTPUT -m limit –limit $MAX_NUM_PACKS/minute <br/>–limit-burst $MAX_NUM_PACKS -j LOG –log-prefix <br/>“IPTABLES_MISS_MATCH_OUTPUT: ”<br/>——————————————<br/>我的样例：<br/>——————————————<br/><br/>#!/bin/sh<br/>#<br/># rc.firewall - Initial SIMPLE IP Firewall script for Linux 2.6.x and iptables<br/>#<br/># Copyright (C) 2006 Oskar Andreasson <bluefluxATkoffeinDOTnet><br/>#<br/># This program is free software; you can redistribute it and/or modify<br/># it under the terms of the GNU General Public License as published by<br/># the Free Software Foundation; version 2 of the License.<br/>#<br/># This program is distributed in the hope that it will be useful,<br/># but WITHOUT ANY WARRANTY; without even the implied warranty of<br/># MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the<br/># GNU General Public License for more details.<br/>#<br/># You should have received a copy of the GNU General Public License<br/># along with this program or from the site that you downloaded it<br/># from; if not, write to the Free Software Foundation, Inc., 59 Temple<br/># Place, Suite 330, Boston, MA 02111-1307 USA<br/>#<br/>###########################################################################<br/>#<br/># 1. Configuration options.<br/>#<br/>#<br/># 1.1 Internet Configuration.<br/>#<br/>INET_IP=”1.2.3.4″<br/>INET_IP_1=”1.2.3.5″<br/>INET_IFACE=”eth0″<br/>INET_BROADCAST=”1.2.3.127″<br/>#<br/># 1.1.1 DHCP<br/>#<br/>#<br/># 1.1.2 PPPoE<br/># 1.2 Local Area Network configuration.<br/>#<br/># your LAN’s IP range and localhost IP. /24 means to only use the first 24<br/># bits of the 32 bit IP address. the same as netmask 255.255.255.0<br/>#<br/>LAN_IP=”192.168.0.33″<br/>LAN_IP_RANGE=”192.168.0.0/24″<br/>LAN_IFACE=”eth1″<br/>#<br/># 1.3 DMZ Configuration.<br/>#<br/>#<br/># 1.4 Localhost Configuration.<br/>#<br/>LO_IFACE=”lo”<br/>LO_IP=”127.0.0.1″<br/>#<br/># 1.5 IPTables Configuration.<br/>#<br/>IPTABLES=”/sbin/iptables”<br/>#<br/># 1.6 Other Configuration.<br/>#<br/>###########################################################################<br/>#<br/># 2. Module loading.<br/>#<br/>#<br/># Needed to initially load modules<br/>/sbin/depmod -a<br/>#<br/># 2.1 Required modules<br/>#<br/>/sbin/modprobe ip_tables<br/>/sbin/modprobe ip_conntrack<br/>/sbin/modprobe iptable_filter<br/>#/sbin/modprobe iptable_mangle<br/>#/sbin/modprobe iptable_nat<br/>/sbin/modprobe ipt_LOG<br/>/sbin/modprobe ipt_limit<br/>/sbin/modprobe ipt_state<br/>#<br/># 2.2 Non-Required modules<br/>#<br/>#/sbin/modprobe ipt_owner<br/>#/sbin/modprobe ipt_REJECT<br/>#/sbin/modprobe ipt_MASQUERADE<br/>#/sbin/modprobe ip_conntrack_ftp<br/>#/sbin/modprobe ip_conntrack_irc<br/>#/sbin/modprobe ip_nat_ftp<br/>#/sbin/modprobe ip_nat_irc<br/>###########################################################################<br/>#<br/># 3. /proc set up.<br/>#<br/>#<br/># 3.1 Required proc configuration<br/>#<br/>#echo ”1″ > /proc/sys/net/ipv4/ip_forward<br/>echo ”1″ > /proc/sys/net/ipv4/tcp_syncookies<br/>echo ”1″ > /proc/sys/net/ipv4/icmp_ignore_bogus_error_responses<br/># 3.2 Non-Required proc configuration<br/>#<br/>#echo ”1″ > /proc/sys/net/ipv4/conf/all/rp_filter<br/>#echo ”1″ > /proc/sys/net/ipv4/conf/all/proxy_arp<br/>#echo ”1″ > /proc/sys/net/ipv4/ip_dynaddr<br/>#echo ”1″ > /proc/sys/net/ipv4/tcp_syncookies<br/>#启用反向路径源认证,防止欺骗<br/>#echo ”1″ > /proc/sys/net/ipv4/conf/all/rp_filter<br/>#关闭 icom echo 广播包请求<br/>#echo ”1″ > /proc/sys/net/ipv4/icmp_echo_ignore_broadcasts<br/>#拒绝源路由包<br/>#echo ”0″ > /proc/sys/net/ipv4/conf/all/accept_source_route<br/>#仅仅接收发给默认网关列表中网关的ICMP重定向消息<br/>#echo ”1″ > /proc/sys/net/ipv4/conf/all/secure_redirects<br/>#记录来自非法ip的请求<br/>#echo ”1″ > /proc/sys/net/ipv4/conf/all/log_martians<br/>###########################################################################<br/>#<br/># 4. rules set up.<br/>#<br/>######<br/># 4.1 Filter table<br/>#<br/>#<br/># 4.1.1 Set policies<br/>#<br/>$IPTABLES -F<br/>$IPTABLES -X<br/>$IPTABLES -F -t mangle<br/>$IPTABLES -t mangle -X<br/>$IPTABLES -F -t nat<br/>$IPTABLES -t nat -X<br/>$IPTABLES -P INPUT DROP<br/>$IPTABLES -P OUTPUT DROP<br/>$IPTABLES -P FORWARD DROP<br/>#<br/># 4.1.2 Create userspecified chains<br/>#<br/>#<br/># Create chain for bad tcp packets<br/>#<br/>$IPTABLES -N bad_tcp_packets<br/>#<br/># Create separate chains for ICMP, TCP and UDP to traverse<br/>#<br/>$IPTABLES -N allowed<br/>$IPTABLES -N tcp_packets<br/>$IPTABLES -N udp_packets<br/>$IPTABLES -N icmp_packets<br/>#<br/># 4.1.3 Create content in userspecified chains<br/>#<br/>#<br/># bad_tcp_packets chain<br/>#<br/>$IPTABLES -A bad_tcp_packets -p tcp –tcp-flags SYN,ACK SYN,ACK -m state --state NEW -j REJECT –reject-with tcp-reset<br/>$IPTABLES -A bad_tcp_packets -p tcp ! –syn -m state --state NEW -j LOG –log-prefix ”New not syn:”<br/>#$IPTABLES -A bad_tcp_packets -p tcp ! –syn -m state --state NEW -j DROP<br/>#$IPT -A bad_packets -p ALL -m state --state INVALID -j LOG –log-prefix ”IPTABLES_INVALID_PACKET:”<br/>#$IPT -A bad_packets -p ALL -m state --state INVALID -j DROP<br/>#<br/># allowed chain<br/>#<br/>$IPTABLES -A allowed -p TCP –syn -j ACCEPT<br/>$IPTABLES -A allowed -p TCP -m state --state ESTABLISHED,RELATED -j ACCEPT<br/>$IPTABLES -A allowed -p TCP -j DROP<br/>#<br/># TCP rules<br/>#<br/>#$IPTABLES -A tcp_packets -p TCP -s 0/0 --dport 21 -j allowed<br/>$IPTABLES -A tcp_packets -p TCP -s 0/0 --dport 30000 -j allowed<br/>#$IPTABLES -A tcp_packets -p TCP -s 0/0 --dport 22 -j allowed<br/>$IPTABLES -A tcp_packets -p TCP -s 0/0 --dport 80 -j allowed<br/>$IPTABLES -A tcp_packets -p TCP -s 0/0 --dport 10050 -j allowed<br/>$IPTABLES -A tcp_packets -p TCP -s 0/0 --dport 10051 -j allowed<br/>$IPTABLES -A tcp_packets -p TCP -s 0/0 -d $INET_IP_1 --dport 25 -j allowed<br/>$IPTABLES -A tcp_packets -p TCP -s 0/0 -d $INET_IP_1 --dport 110 -j allowed<br/>#$IPTABLES -A tcp_packets -p TCP -s 0/0 --dport 2009 -j allowed<br/>#<br/># UDP ports<br/>#<br/>#$IPTABLES -A udp_packets -p UDP -s 0/0 –destination-port 53 -j ACCEPT<br/>#$IPTABLES -A udp_packets -p UDP -s 0/0 –destination-port 123 -j ACCEPT<br/>#$IPTABLES -A udp_packets -p UDP -s 0/0 –destination-port 2074 -j ACCEPT<br/>#$IPTABLES -A udp_packets -p UDP -s 0/0 –destination-port 4000 -j ACCEPT<br/>#<br/># In Microsoft Networks you will be swamped by broadcasts. These lines<br/># will prevent them from showing up in the logs.<br/>#<br/>$IPTABLES -A udp_packets -p UDP -i $INET_IFACE -d $INET_BROADCAST –destination-port 135:139 -j DROP<br/>#<br/># If we get DHCP requests from the Outside of our network, our logs will<br/># be swamped as well. This rule will block them from getting logged.<br/>#<br/>$IPTABLES -A udp_packets -p UDP -i $INET_IFACE -d 255.255.255.255 –destination-port 67:68 -j DROP<br/>#<br/># ICMP rules<br/>#<br/>$IPTABLES -A icmp_packets -p ICMP -s 0/0 –icmp-type 8 -j ACCEPT<br/>$IPTABLES -A icmp_packets -p ICMP -s 0/0 –icmp-type 11 -j ACCEPT<br/>#<br/># 4.1.4 INPUT chain<br/>#<br/>#<br/># Bad TCP packets we don’t want.<br/>#<br/>$IPTABLES -A INPUT -p tcp -j bad_tcp_packets<br/>#<br/># Special rule for DHCP requests from LAN, which are not caught properly<br/># otherwise.<br/>#<br/>#$IPTABLES -A INPUT -p UDP -i $LAN_IFACE --dport 67 –sport 68 -j ACCEPT<br/>#<br/># Rules for incoming packets from the internet.<br/>#<br/>$IPTABLES -A INPUT -p ALL -d $INET_IP -m state --state ESTABLISHED,RELATED -j ACCEPT<br/>$IPTABLES -A INPUT -p ALL -d $INET_IP_1 -m state --state ESTABLISHED,RELATED -j ACCEPT<br/>$IPTABLES -A INPUT -p TCP -i $INET_IFACE -j tcp_packets<br/>$IPTABLES -A INPUT -p UDP -i $INET_IFACE -j udp_packets<br/>$IPTABLES -A INPUT -p ICMP -i $INET_IFACE -j icmp_packets<br/># Rules for special networks not part of the Internet<br/>#<br/>$IPTABLES -A INPUT -p ALL -i $LAN_IFACE -s $LAN_IP_RANGE -j ACCEPT<br/>$IPTABLES -A INPUT -p ALL -i $LO_IFACE -s $LO_IP -j ACCEPT<br/>$IPTABLES -A INPUT -p ALL -i $LO_IFACE -s $LAN_IP -j ACCEPT<br/>$IPTABLES -A INPUT -p ALL -i $LO_IFACE -s $INET_IP -j ACCEPT<br/>$IPTABLES -A INPUT -p ALL -i $LO_IFACE -s $INET_IP_1 -j ACCEPT<br/>#<br/># If you have a Microsoft Network on the outside of your firewall, you may<br/># also get flooded by Multicasts. We drop them so we do not get flooded by<br/># logs<br/>#<br/>$IPTABLES -A INPUT -i $INET_IFACE -d 224.0.0.0/8 -j DROP<br/>#<br/># Log weird packets that don’t match the above.<br/>#<br/>$IPTABLES -A INPUT -m limit –limit 3/minute –limit-burst 3 -j LOG –log-level DEBUG –log-prefix ”IPT INPUT packet died: ”<br/>#<br/># 4.1.5 FORWARD chain<br/>#<br/>#<br/># Bad TCP packets we don’t want<br/>#<br/>#$IPTABLES -A FORWARD -p tcp -j bad_tcp_packets<br/>#<br/># Accept the packets we actually want to forward<br/>#<br/>#$IPTABLES -A FORWARD -i $LAN_IFACE -j ACCEPT<br/>#$IPTABLES -A FORWARD -m state --state ESTABLISHED,RELATED -j ACCEPT<br/>#<br/># Log weird packets that don’t match the above.<br/>#$IPTABLES -A FORWARD -m limit –limit 3/minute –limit-burst 3 -j LOG –log-level DEBUG –log-prefix ”IPT FORWARD packet died: ”<br/>#<br/># 4.1.6 OUTPUT chain<br/>#<br/>#<br/># Bad TCP packets we don’t want.<br/>#<br/>$IPTABLES -A OUTPUT -p tcp -j bad_tcp_packets<br/>#<br/># Special OUTPUT rules to decide which IP’s to allow.<br/>#<br/>$IPTABLES -A OUTPUT -p ALL -s $LO_IP -j ACCEPT<br/>$IPTABLES -A OUTPUT -p ALL -s $LAN_IP -j ACCEPT<br/>$IPTABLES -A OUTPUT -p ALL -s $INET_IP -j ACCEPT<br/>$IPTABLES -A OUTPUT -p ALL -s $INET_IP_1 -j ACCEPT<br/>#<br/># Log weird packets that don’t match the above.<br/>#<br/>#$IPTABLES -A OUTPUT -m limit –limit 3/minute –limit-burst 3 -j LOG –log-level DEBUG –log-prefix ”IPT OUTPUT packet died: ”<br/>######<br/># 4.2 nat table<br/>#<br/>#<br/># 4.2.1 Set policies<br/>#<br/>#<br/># 4.2.2 Create user specified chains<br/>#<br/>#<br/># 4.2.3 Create content in user specified chains<br/>#<br/>#<br/># 4.2.4 PREROUTING chain<br/>#<br/>#<br/># 4.2.5 POSTROUTING chain<br/>#<br/>#<br/># Enable simple IP Forwarding and Network Address Translation<br/>#<br/>#$IPTABLES -t nat -A POSTROUTING -o $INET_IFACE -j SNAT –to-source $INET_IP<br/>#<br/># 4.2.6 OUTPUT chain<br/>#<br/>######<br/># 4.3 mangle table<br/>#<br/>#<br/># 4.3.1 Set policies<br/>#<br/>#<br/># 4.3.2 Create user specified chains<br/>#<br/>#<br/># 4.3.3 Create content in user specified chains<br/>#<br/>#<br/># 4.3.4 PREROUTING chain<br/>#<br/>#<br/># 4.3.5 INPUT chain<br/>#<br/>#<br/># 4.3.6 FORWARD chain<br/>#<br/>#<br/># 4.3.7 OUTPUT chain<br/>#<br/>#<br/># 4.3.8 POSTROUTING chain<br/>#<br/>------------------------------------<br/><br/><br/>Tags - <a href="http://www.dzhope.com/tags/iptables/" rel="tag">iptables</a> , <a href="http://www.dzhope.com/tags/iptables%25E5%25B8%25B8%25E7%2594%25A8%25E8%25A7%2584%25E5%2588%2599/" rel="tag">iptables常用规则</a>
]]>
</description>
</item><item>
<link>http://www.dzhope.com/post//#blogcomment</link>
<title><![CDATA[[评论] Linux的iptables常用配置范例（1）]]></title> 
<author> &lt;user@domain.com&gt;</author>
<category><![CDATA[评论]]></category>
<pubDate>Thu, 01 Jan 1970 00:00:00 +0000</pubDate> 
<guid>http://www.dzhope.com/post//#blogcomment</guid> 
<description>
<![CDATA[ 
	
]]>
</description>
</item>
</channel>
</rss>