iptables概述
Linux系统的防火墙实际上是由两个组件 netfilter 和 iptables 组成
主要工作在网络层,针对IP数据包。对包内的IP地址、端口等信息进行处理
netfilter
内核空间的防火墙功能体系
由数据报过滤表组成,表里有规则
iptables
用户空间的防火墙管理体系
一种命令程序(/sbin/iptables)
一般这两个统称为iptables
四表五链
iptables内置了4个规则表,每个表里都有些规则链,总计有5种链
规则表 | 作用 | 规则链 |
---|---|---|
mangle | 修改数据包内容,用来做流量整形的,给数据包设置标记 | INPUT、OUTPUT、FORWARD、PREROUTING、POSTROUTING |
raw | 确定是否对该数据包进行状态跟踪 | OUTPUT、PREROUTING |
nat | 负责网络地址转换,用来修改数据包中的源、目标IP地址或端口 | FORWARD、PREROUTING、POSTROUTING |
filter | 负责过滤数据包,确定是否放行该数据包 | INPUT、OUTPUT、FORWARD |
- INPUT:处理入站数据包,匹配目标IP为本机的数据包
- OUTPUT:处理出站数据包,一般不在此链上做配置
- FORWARD:处理转发数据包,匹配流经本机的数据包
- PREROUTING:在进行路由选择前处理数据包,用来修改目的地址,用来做DNAT
相当于把内网服务器的IP和端口映射到路由器的外网TP和端口上 - POSTROUTING:在进行路由选择后处理数据包,用来修改源地址,用来做SNAT
相当于内网通过路由器NAT转换功能实现内网主机通过个公网IP地址上网
表中所有规则配置后,立即生效,不需要重启服务
匹配顺序及规则
规则链之间的匹配顺序
主机型防火墙:
入站数据(来自外界的数据包,且目标地址是防火墙本机)
PREROUTING — INPUT — 本机的应用程序
出站数据(从防火墙本机向外部地址发送的数据包)
本机的应用程序 — OUTPUT — POSTROUTING
网络型防火墙:
转发数据(需要经过防火墙转发的数据包)
PREROUTING — FORWARD — POSTROUTING
规则链内的匹配规则
自上向下按顺序依次进行检查,找到相匹配的规则即停止
若在该链内找不到相匹配的规则,则按该链的默认策略处理(未修改的状况下,默认策略为允许)
相关配置
命令格式
iptables [-t 表名] 管理选项〔链名] [匹配条件] [-j 控制类型]
管理选项
选项 | 作用 |
---|---|
-A | 在指定链的末尾追加一条新的规则 |
-I | 在指定链的开头插入一条新的规则,未指定序号时默认作为第一条规则 |
-R | 修改、替换指定链中的某一条规则,可指定规则序号或具体内容 |
-P | 设置指定链的默认策略 |
-D | 删除指定链中的某一条规则,可指定规则序号或具体内容 |
-F | 清空指定链中的所有规则,若未指定链名,则清空表中的所有链 |
-L | 列出指定链中所有的规则,若未指定链名,则列出表中的所有链 |
-n | 使用数字形式显示输出结果,如显示IP地址而不是主机名 |
-V | 显示详细信息,包括每条规则的匹配包数量和匹配字节数 |
-p | 指定协议 |
–dport | 指定端口号 |
–line-numbers | 查看规则时,显示规则的序号 |
控制类型
类型 | 作用 |
---|---|
ACCEPT | 允许数据包通过 |
REJECT | 拒绝数据包通过,会给数据发送端一个响应信息 |
DROP | 直接丢弃数据包,不给出任何回应信息 |
SNAT | 修改数据包的源地址 |
DNAT | 修改数据包的目的地址 |
MASQUERADE | 伪装成一个非固定公网IP地址 |
LOG | 在/var/log/messages文件中记录日志信息,然后将数据包传递给下一条规则。LOG只是一种辅助动作,并没有真正处理数据包 |
示例
相关匹配注意事项
通用匹配
协议匹配:-p 协议名
地址匹配:-s 源地址、-d 目的地址 #可以是IP、网段、域名、空(任何地址)
接口匹配:-i 入站网卡、-o 出站网卡
隐含匹配
端口匹配 - -sport源端口、- -dport 目的端口
--sport和 --dport必须配合-p<协议类型>使用
#可以是个别端口、端口范围
匹配源端口是1000的数据包: - -sport 1000
匹配源端口是1000-3000的数据包:- -sport 1000 : 3000
匹配源端口是3000及以下的数据包:- -sport : 3000
匹配源端口是1000及以上的数据包:- -sport 1000:
状态匹配
-mstate --state 连接状态
常见的连接状态
NEW :与任何连接无关的,还没开始连接
ESTABLISHED :响应请求或者已建立连接的,连接态
RELATED:与已有连接有相关性的(如FTP主被动模式的数据连接),衍生态,一般与ESTABLISHED配合使用
INVALID :不能被识别属于哪个连接或没有任何状态