Linux 防火墙 iptables技术

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 :不能被识别属于哪个连接或没有任何状态

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值