iptables解释


RHEL5.4 iptables 配置详解(图) - zhuzhu - 津津计较


RHEL5.4 iptables 配置详解(图) - zhuzhu - 津津计较

第一种情况:入站数据流向

   从外界到达防火墙的数据包,先被PREROUTING规则链处理(是否修改数据包地址等),之后会进行路由选择(判断该数据包应该发往何处),如果数据包的目标主机是防火墙本机(比如说Internet用户访问防火墙主机中的web服务器的数据包),那么内核将其传给INPUT链进行处理(决定是否允许通过等),通过以后再交给系统上层的应用程序(比如Apache服务器)进行响应。

第二冲情况:转发数据流向

   来自外界的数据包到达防火墙后,首先被PREROUTING规则链处理,之后会进行路由选择,如果数据包的目标地址是其它外部地址(比如局域网用户通过网关访问QQ站点的数据包),则内核将其传递给FORWARD链进行处理(是否转发或拦截),然后再交给POSTROUTING规则链(是否修改数据包的地址等)进行处理。

第三种情况:出站数据流向
    防火墙本机向外部地址发送的数据包(比如在防火墙主机中测试公网DNS服务器时),首先被OUTPUT规则链处理,之后进行路由选择,然后传递给POSTROUTING规则链(是否修改数据包的地址等)进行处理。



路由是这样的判断ip是否在同一网段如果是就不走路由,如果不是就需要根据网关出去。

-i 进入路由器 �Co 从路由器出去

防火墙的分类:包过滤防火墙、内容过滤防火墙、状态机制防火墙

一、iptables表链结构及作用

  1filter(包过滤)

      INPUT:过滤给本机的包

      OUTPUT:过滤本机发出去的包

      FORWARD:过滤转发的包

  2nat(修改源、目标ip或端口)

      PREROUTING:转换数据包目标IP地址(DNAT

       POSTROUTING:转换数据包源IP地址(SNAT

      OUTPUT:转换本机发出的数据包的目标IP地址(DNAT

  3mangle(标记)

设置标记

  4raw(状态跟踪)

是否跳过NAT表处理

  5.数据流向

入站:PREROUTINGàINPUT

出站:OUTPUTàPOSTROUTING

转发:PREROUTINGàFORWARDàPOSTROUTING

      6.表优先级

             rawàmangleànatàfilter

二、iptables命令

      1iptables语法格式

             #iptables[-t 表名] 命令选项 [链名] [条件匹配] [-j 目标动作或跳转]

   2-t  表名

表名可以是rawmanglenatfilter,默认值是filter

      3.命令选项

             -A  追加规则

             -I   插入规则

             -R  替换规则

             -D  删除规则

             -F  清空规则

             -P  默认规则

             -N  定义新链

             -X  删除自定义链

             -L  查看规则

                    -n  使用数字显示

                    --line-numbers  显示行号

      4.链名

根据实际要求选择规则要放入的链


通用条件匹配

网络协议、IP地址、网络接口

-p 协议名

-s 源地址、-d 目标地址

-i 网络接口名、-o 网络接口名

隐含条件匹配

端口、TCP标记、ICMP类型

--sport 源端口、--dport 目标端口

--tcp-flags  检查范围被设置的标记

--icmp-type ICMP类型

显式条件匹配

使用“-m 扩展模块

多端口、MAC地址、IP地址范围、数据包状态

-m multiport  --sports 源端口列表、--dports 目标端口列表

-m mac  --mac-source MAC地址

-m iprange   --src-range IP范围、--dst-range 目标IP范围

-m state --state 状态类型

-m connlimit--connlimit-above 并发连接数

-m layer7 --17proto 应用层协议

-m time --timestart 时间--timestop 时间

-m string --staring “匹配策略数据包”

5.条件匹配

             -p  匹配协议

             -d  匹配目标IP

             -s  匹配源IP

             -i  匹配接收接口

             -o  匹配发送接口

             --sport  匹配源端口

             --dport  匹配目标端口

             --tcp-flags  匹配TCP标识位

            -m mac --mac-source  匹配源MAC

             -mmultiport --sport  匹配多个源端口

            -m multiport --dport  匹配多个目标端口

             -miprange --src-range  匹配源IP地址范围

             -miprange --dst-range  匹配目标IP地址范围

             -mstate --state  匹配状态

      6-j 目标动作或跳转

             ACCEPT  允许

             DROP  丢弃

             REJECT  拒绝,给发送端返回信息

             LOG  记录日志,然后把包交给下一条规则处理

三、导入与导出防火墙规则

      1.导出

             #iptables-save  >  /etc/sysconfig/iptables

             #service  iptables  save

     2.导入

             #iptables-restore  <  /etc/sysconfig/iptables



配置iptables防火墙(二)

一、SNAT策略

      1SNAT介绍

IP地址转换,用于内网用户访问Internet

      2.内网(192.168.1.0/24)用户使用同一IP地址(200.1.1.1)访问互联网

# iptables -t nat -A POSTROUTING -s192.168.1.0/24 -o eth1 -j SNAT --to-source 200.1.1.1

      3.内网(192.168.1.0/24)用户使用同一IP地址(ADSL拨号)访问互联网

# iptables -t nat-A POSTROUTING -s 192.168.1.0/24 -o ppp0 -j MASQUERADE

二、DNAT策略

      1DNAT介绍

目标IP地址转换,用于Internet用户访问公司内网服务器

      2.把Internet用户访问WEB服务器的数据包转换成实际WEB服务器IP地址

# iptables  -t nat -A PREROUTING -d 200.1.1.1 -p tcp--dport 80 -j DNAT --to-destination 192.168.2.100



举例:

iptables -t filter -A INPUT -j DROP

在filter 表的INPUT 链里追加一条规则(作为最后一条规则)匹配所有访问本机IP 的数据包,匹配到的丢弃

iptables  -A INPUT -j DROP

由于防火墙中filter是默认的,所以防火墙规则也可以省略表 -t fileter项



iptables -I INPUT -j DROP

在filter 表的INPUT 链里插入一条规则(插入成第1 条)

iptables -I INPUT 3 -j DROP

在filter 表的INPUT 链里插入一条规则(插入成第3 条)


iptables -D INPUT 3(按号码匹配)
删除filter 表INPUT 链中的第三条规则(不管它的内容是什么)
iptables -D INPUT -s 192.168.0.1 -j DROP(按内容匹配)
删除filter 表INPUT 链中内容为“-s 192.168.0.1 -j DROP”的规则(不管其位置在哪里)


iptables -R INPUT 3 -j ACCEPT

将原来编号为3 的规则内容替换为“-j ACCEPT”


iptables -P INPUT DROP
设置filter 表INPUT 链的默认规则是DROP


iptables -F INPUT
清空filter 表INPUT 链中的所有规则
iptables -t nat -F PREROUTING
清空nat 表PREROUTING 链中的所有规则


iptables -L
粗略列出filter 表所有链及所有规则
iptables -t nat -vnL
用详细方式列出nat 表所有链的所有规则,只显示IP 地址和端口号
iptables -t nat -vxnL PREROUTING
用详细方式列出nat 表PREROUTING 链的所有规则以及详细数字,不反解


-i eth0 匹配是否从网络接口eth0 进来
-o 匹配数据流出的网络接口


-s 192.168.0.1 匹配来自192.168.0.1 的数据包
-s 192.168.1.0/24 匹配来自192.168.1.0/24 网络的数据包


-d 202.106.0.20 匹配去往202.106.0.20 的数据包
-d 202.106.0.0/16 匹配去往202.106.0.0/16 网络的数据包
-d www.abc.com 匹配去往域名www.abc.com 的数据包


-p tcp       #协议后面跟端口
-p udp
-p icmp --icmp-type 类型

ping: type 8 pong: type 0


--sport 1000 匹配源端口是1000 的数据包
--sport 1000:3000 匹配源端口是1000-3000 的数据包(含1000、3000)
--sport :3000 匹配源端口是3000 以下的数据包(含3000)
--sport 1000: 匹配源端口是1000 以上的数据包(含1000)
--dport <匹配目的端口>


--dport 80 匹配目的端口是80 的数据包
--dport 6000:8000 匹配目的端口是6000-8000 的数据包(含6000、8000)
--dport :3000 匹配目的端口是3000 以下的数据包(含3000)
--dport 1000: 匹配目的端口是1000 以上的数据包(含1000)


-p udp --dport 53       #协议和端口是一组的,控制端口必须写协议

匹配网络中目的端口是53 的UDP 协议数据包



-s 10.1.0.0/24 -d 172.17.0.0/16
匹配来自10.1.0.0/24 去往172.17.0.0/16 的所有数据包


-s 192.168.0.1 -d www.abc.com -p tcp --dport 80
匹配来自192.168.0.1,去往www.abc.com 的80 端口的TCP 协议数据包


iptables -A INPUT -j ACCEPT
允许所有访问本机IP 的数据包通过


iptables -A FORWARD -s 192.168.80.39 -j DROP
阻止来源地址为192.168.80.39 的数据包通过本机


iptables -t nat -A PREROUTING -i ppp0 -p tcp --dport 80 -j DNAT --to 192.168.0.1
把从ppp0 进来的要访问TCP/80 的数据包目的地址改为192.168.0.1
iptables -t nat -A PREROUTING -i ppp0 -p tcp --dport 81 -j DNAT --to 192.168.0.2:80

iptables -t nat -A PREROUTING -i ppp0 -p tcp --dport 80 -j DNAT --to 192.168.0.1-192.168.0.10


iptables -t nat -A POSTROUTING -s 192.168.0.0/24 -j SNAT --to 1.1.1.1
将内网192.168.0.0/24 的原地址修改为1.1.1.1,用于NAT
iptables -t nat -A POSTROUTING -s 192.168.0.0/24 -j SNAT --to 1.1.1.1-1.1.1.10

同上,只不过修改成一个地址池里的IP


iptables -t nat -A POSTROUTING -s 192.168.0.0/24 -j MASQUERADE
将源地址是192.168.0.0/24 的数据包进行地址伪装


iptables -A FORWARD -d 192.168.0.1 -m limit --limit 50/s -j ACCEPT


单机防护墙配置

iptables -A INPUT -i lo -j ACCEPT
iptables -A INPUT -p tcp -m multiport --dports 22,80 -j ACCEPT
iptables -A INPUT -m state --state RELATED,ESTABLISHED -j ACCEPT
iptables -P INPUT DROP


做网关配置

echo "1" > /proc/sys/net/ipv4/ip_forward
iptables -t nat -A POSTROUTING -s 192.168.1.0/24 -o ppp0 -j MASQUERADE


限制内网用户设置

iptables -A FORWARD -s 192.168.0.3 -j DROP
iptables -A FORWARD -m mac --mac-source 11:22:33:44:55:66 -j DROP
iptables -A FORWARD -d bbs.chinaunix.net -j DROP


内网做对外服务设置

iptables -t nat -A PREROUTING -i ppp0 -p tcp --dport 80 -j DNAT --to 192.168.1.1
iptables -t nat -A PREROUTING -i ppp0 -p tcp --dport 81 -j DNAT --to 192.168.1.2:80



你可能感兴趣的:(iptables解释)