一.主要知识点:
* nat表:修改数据包中的源、目标IP地址或端口
* POSTROUTING链:在进行路由选择后处理数据包
* PREROUTING链:在进行路由选择前处理数据包
* 依次为:raw à mangle à nat à filter
* 入站数据:PREROUTING à INPUT
* 出站数据:OUTPUT à POSTROUTING
* 转发数据:PREROUTING à FORWARD à POSTROUTING
* iptables [-t 表名] 管理选项 [链名] [条件匹配] [-j 目标动作或跳转]
* 除非设置规则链的缺省策略,否则需要指定匹配条件
[root@localhost ~]# iptables -t filter -A INPUT -p tcp -j ACCEPT
[root@localhost ~]# iptables -I INPUT -p udp -j ACCEPT
[root@localhost ~]# iptables -I INPUT 2 -p icmp -j ACCEPT
[root@localhost ~]# iptables -P INPUT DROP
[root@localhost ~]# iptables -L INPUT --line-numbers
Chain INPUT (policy DROP)
num target prot opt source destination
1 ACCEPT udp -- anywhere anywhere
2 ACCEPT icmp -- anywhere anywhere
3 ACCEPT tcp -- anywhere anywhere
* 协议名可使用在“/etc/protocols”文件中定义的名称
* 使用“-s 源地址”、 “-d 目标地址”的形式
* 地址可以是单个IP地址、网络地址(带掩码长度)
* 使用“-i 网络接口名”、 “-o 网络接口名”的形式,分别对应接收、发送数据包的网络接口
[root@localhost ~]# iptables -I INPUT -p icmp -j REJECT
[root@localhost ~]# iptables -A FORWARD -p ! icmp -j ACCEPT
[root@localhost ~]# iptables -A FORWARD -s 192.168.1.11 -j REJECT
[root@localhost ~]# iptables -A INPUT -i eth1 -s 172.16.0.0/12 -j DROP
[root@localhost ~]# iptables -A FORWARD -o eth1 -d 61.35.4.3 -j DROP
* 使用“--sport 源端口”、“--dport 目标端口”的形式
* 采用“端口1:端口2”的形式可以指定一个范围的端口
* 使用“--tcp-flags 检查范围 被设置的标记”的形式
* 如“--tcp-flags SYN,RST,ACK SYN”表示检查SYN、RST、ACK这3个标记,只有SYN为1时满足条件
* 使用“--icmp-type ICMP类型”的形式
* ICMP类型可以使用类型字符串或者对应的数值,例如Echo-Request、Echo-Reply
[root@localhost ~]# iptables -A FORWARD -p tcp --dport 22 -j ACCEPT
[root@localhost ~]# iptables -A OUTPUT -p tcp --sport 20:80 -j ACCEPT
[root@localhost ~]# iptables -I INPUT -i eth1 -p tcp --tcp-flags SYN,RST,ACK SYN -j REJECT
[root@localhost ~]# iptables -A INPUT -i eth0 -p icmp --icmp-type Echo-Request -j DROP
[root@localhost ~]# iptables -A INPUT -p icmp --icmp-type Echo-Reply -j ACCEPT
* 使用“-m mac”结合“--mac-source MAC地址”的形式
* 使用“-m multiport”结合“--sports 源端口列表”或者“--dports 目标端口列表”的形式
* 多个端口之间使用逗号“,”分隔,连续的端口也可以使用冒号“:”分隔
* 使用“-m iprange”结合“--src-range 源IP范围”或者“--dst-range 目标IP范围” 的形式
[root@localhost ~]# iptables -A FORWARD -m mac --mac-source 00:0C:29:27:55:3F -j DROP
[root@localhost ~]# iptables -A INPUT -p tcp -m multiport --dport 20,21,25,110,1250:1280 -j ACCEPT
[root@localhost ~]# iptables -A FORWARD -p tcp -m iprange --src-range 192.168.1.20-192.168.1.99 -j DROP
* 用户自定义链名:传递给自定义链内的规则进行处理
[root@localhost ~]# iptables -A INPUT -p tcp --dport 22 -m limit --limit 3/minute --limit-burst 8 -j LOG
[root@localhost ~]# iptables -A INPUT -p tcp --dport 22 -j DROP
[root@localhost ~]# iptables -t nat -A POSTROUTING -s 192.168.1.0/24 -o eth0 -j SNAT --to-source 218.29.30.31
[root@localhost ~]# iptables -t nat -A POSTROUTING -s 192.168.1.0/24 -o eth0 -j MASQUERADE
[root@localhost ~]#iptables -t nat -A PREROUTING -i eth0 -d 218.29.30.31 -p tcp --dport 80 -j DNAT --to-destination 192.168.1.6(:80)
* 添加内核补丁,重新编译内核,并以新内核引导系统
* 添加iptables补丁,重新编译安装iptables
* Linux内核源码包:linux-2.6.28.8.tar.bz2
* iptables源码包:iptables-1.4.2.tar.bz2
* layer7补丁源码包:netfilter-layer7-v2.21.tar.gz
* 协议定义包:l7-protocols-2009-05-10.tar.gz
* 匹配格式:-m layer7 --l7proto 协议名
* msnmessenger:微软公司MSN程序的通讯协议
* msn-filetransfer:MSN程序的文件传输协议
* bittorrent:BT下载类软件使用的通讯协议
* 其他各种应用层协议:ftp、http、dns、imap、pop3……
* iptables -A FORWARD -m layer7 --l7proto qq -j DROP
* FTP相关:ip_nat_ftp、ip_conntrack_ftp
* 方法1:/sbin/sysctl -w net.ipv4.ip_forward=1
* 方法2:echo 1 > /proc/sys/net/ipv4/ip_forward
* 方法3:修改/etc/sysctl.conf,设置 net.ipv4.ip_forward = 1
/sbin/modprobe ip_nat_ftp
#------------------------default rule ------------------------------
#------------------------limit packet per second------------------------------
/sbin/iptables -A INPUT -f -m limit --limit 100/sec --limit-burst 100 -j ACCEPT
/sbin/iptables -A INPUT -p tcp -m tcp --tcp-flags SYN,RST,ACK SYN -m limit --limit 20/sec --limit-burst 200 -j ACCEPT
/sbin/iptables -A INPUT -p icmp -m limit --limit 12/min --limit-burst 2 -j DROP
#------------------------ssh rule -------------------------------------------
iptables -t filter -A INPUT -i eth0 -p tcp --dport 22 -j ACCEPT
iptables -t filter -A OUTPUT -o eth0 -p tcp --sport 22 -j ACCEPT
#------------------------www-ftp-mail-dns rule --------------------------------
iptables -t filter -A INPUT -i eth0 -p tcp --dport 80 -j ACCEPT
iptables -t filter -A OUTPUT -o eth0 -p tcp --sport 80 -j ACCEPT
#-------------------------ICMP rule ------------------------------------------
iptables -A INPUT -p icmp --icmp-type echo-request -j ACCEPT
iptables -A INPUT -p icmp --icmp-type echo-reply -j ACCEPT
iptables -A OUTPUT -p icmp --icmp-type echo-request -j ACCEPT
iptables -A OUTPUT -p icmp --icmp-type echo-reply -j ACCEPT