Linux iptables基本使用

相关概念

防火墙除了软件及硬件的分类,也可对数据封包的取得方式来分类,可分为代理服务器(Proxy)封包过滤机制(IP Filter)。代理服务是一种网络服务,通常就架设在路由上面,可完整的掌控局域网的对外连接。IP Filter这种方式可以直接分析最底层的封包表头数据来进行过滤,所以包括 MAC地址、IP、TCP、 UDP、ICMP 等封包的信息都可以进行过滤分析的功能,用途非常广泛。其实Iptables服务不是真正的防火墙,只是用来定义防火墙规则功能的"防火墙管理工具",将定义好的规则交由内核中的netfilter即网络过滤器来读取,从而真正实现防火墙功能。

(一)iptables抵挡封包的方式:

  1. 拒绝让Internet的封包进入Linux主机某些port
  2. 拒绝让某些来源IP的封包进入
  3. 拒绝让带有某些特殊标志( flag )的封包进入
  4. 分析硬件地址(MAC)来提供服务

(二)iptables命令中设置数据过滤或处理数据包的策略叫做规则,将多个规则合成一个链,叫规则链。

规则链则依据处理数据包的位置不同分类:

PREROUTING: 在进行路由判断之前所要进行的规则(DNAT/REDIRECT)
INPUT: 处理入站的数据包
OUTPUT: 处理出站的数据包
FORWARD: 处理转发的数据包
POSTROUTING: 在进行路由判断之后所要进行的规则(SNAT/MASQUERADE)

(三)iptables中的规则表是用于容纳规则链,规则表默认是允许状态的,那么规则链就是设置被禁止的规则,而反之如果规则表是禁止状态的,那么规则链就是设置被允许的规则。

**raw表:**确定是否对该数据包进行状态跟踪

**mangle表:**为数据包设置标记(较少使用)

**nat表:**修改数据包中的源、目标IP地址或端口

**filter表:**确定是否放行该数据包(过滤)

规则表的先后顺序:raw→mangle→nat→filter

规则链的先后顺序:

**入站顺序:**PREROUTING→INPUT

**出站顺序:**OUTPUT→POSTROUTING

**转发顺序:**PREROUTING→FORWARD→POSTROUTING

内建表与链的关系流程图(去掉了mangle表):

另外注意:

1.没有指定规则表则默认指filter表。

2.不指定规则链则指表内所有的规则链。

3.在规则链中匹配规则时会依次检查,匹配即停止(LOG规则例外),若没匹配项则按链的默认状态处理。

(四)iptables命令中则常见的控制类型有:

ACCEPT: 允许通过.
LOG: 记录日志信息,然后传给下一条规则继续匹配.
REJECT: 拒绝通过,必要时会给出提示.
**DROP:**直接丢弃,不给出任何回应.

iptables命令基本参数和用法

**(一)格式为:**iptables [-t 表名] 选项 [链名] [条件] [-j 控制类型]

例如:

"iptables --[A|I 链] [-i|o 网络接口] [-p 协议] [-s 来源ip/网域] [-d 目标ip/网域] --j[ACCEPT|DROP]"

下表格为几乎所有常用的iptables参数:

|-------------|-----------------------------------------|
| 参数 | 作用 |
| -P | 设置默认策略:iptables -P INPUT (DROP|ACCEPT) |
| -F | 清空规则链 |
| -L | 查看规则链 |
| -A | 在规则链的末尾加入新规则 |
| -I num | 在规则链的头部加入新规则 |
| -D num | 删除某一条规则 |
| -s | 匹配来源地址IP/MASK,加叹号"!"表示除这个IP外。 |
| -d | 匹配目标地址 |
| -i 网卡名称 | 匹配从这块网卡流入的数据 |
| -o 网卡名称 | 匹配从这块网卡流出的数据 |
| -p | 匹配协议,如tcp,udp,icmp |
| --dport num | 匹配目标端口号 |
| --sport num | 匹配来源端口号 |

(二)Iptables规则查看与清除

查看:

清除:

策略(Policy)的清除:

(三)Iptables开放网口与ip来源

例:所有的来自lo这个网口的封包,都予以接受

iptables --A INPUT --i lo --j ACCEPT

例:目标来自192.168.1.200这个IP的封包都予以接受

iptables --A INPUT --i eth0 --s 192.168.1.200 --j ACCEPT

例:192.168.1.0/24可接受,但192.168.1.10丢弃

iptalbes --A INPUT --i eth0 --s 192.168.1.0/24 --j ACCEPT

iptables -A INPUT -i eth0 -s 192.168.1.10 -j DROP

(四)Iptables规则记录

例:# iptables -A INPUT -s 192.168.1.200 -j LOG

相关信息就会被写入到/var/log/messages当中,然后该封包会继续进行后续的规则比对。LOG这个动作仅在进行记录而已,并不会影响到这个封包的其它规则比对的。

(五)Iptables开放tcp、udp端口

例:开放samba端口(udp137,138;tcp139,445)

iptables --A INPUT --i eth0 --p udp --dport 137:138 --j ACCEPT

iptables --A INPUT --i eth0 --p tcp --dport 139--j ACCEPT

iptables --A INPUT --i eth0 --p tcp --dport 445--j ACCEPT

(六)iptables匹配ICMP端口和ICMP类型

iptables --A INPUT --p icmp --icmp-type 类型 --j ACCEPT

参数:--icmp-type :后面必须要接 ICMP 的封包类型,也可以使用代号,

(七)Iptables --syn的处理方式

指定TCP匹配扩展

使用 --tcp-flags 选项可以根据tcp包的标志位进行过滤。

#iptables -A INPUT -p tcp --tcp-flags SYN,FIN,ACK SYN

#iptables -A FROWARD -p tcp --tcp-flags ALL SYN,ACK

上实例中第一个表示SYN、ACK、FIN的标志都检查,但是只有SYN匹配。第二个表示ALL(SYN,ACK,FIN,RST,URG,PSH)的标志都检查,但是只有设置了SYN和ACK的匹配。

#iptables -A FORWARD -p tcp --syn

选项---syn相当于"--tcp-flags SYN,RST,ACK SYN"的简写。

(八)Iptables状态模块

例:只要已建立或相关封包就予以通过,只要是不合法封包就丢弃

iptables --A INPUT --m state --state RELATED ESTABLISHED --j ACCEPT

iptables --A INPUT --m state --state INVALID --j DORP

例:对局域网内mac地址为00:0C:29:56:A6:A2主机开放其联机

[root@linux ~]# iptables -A INPUT -m mac --mac-source 00:0C:29:56:A6:A2 -j ACCEPT

(九)Iptables保存于恢复

iptables-save > /etc/sysconfig/iptables.log

iptables-restore < /etc/sysconfig/iptables.log

相关推荐
惜.己15 小时前
Jmeter中的断言(二)
测试工具·jmeter·1024程序员节
西电研梦1 天前
考研倒计时30天丨和西电一起向前!再向前!
人工智能·考研·1024程序员节·西电·西安电子科技大学
惜.己1 天前
Jmeter中的断言(四)
测试工具·jmeter·1024程序员节
·云扬·1 天前
Java IO 与 BIO、NIO、AIO 详解
java·开发语言·笔记·学习·nio·1024程序员节
网安_秋刀鱼1 天前
PHP代码审计 --MVC模型开发框架&rce示例
开发语言·web安全·网络安全·php·mvc·1024程序员节
HUODUNYUN2 天前
小程序免备案:快速部署与优化的全攻略
服务器·网络·web安全·小程序·1024程序员节
惜.己2 天前
Jmeter的后置处理器(二)
测试工具·github·1024程序员节
惜.己2 天前
Jmeter中的断言(一)
测试工具·jmeter·1024程序员节
cainiao0806052 天前
《物理学进展》
1024程序员节·核心期刊·知网期刊·职称评审
FFDUST3 天前
C++ —— string类(上)
c语言·开发语言·数据结构·c++·stl·1024程序员节