Linux下防火墙iptables设置

我手里有本《鸟哥的Linux私房菜-服务器架设篇》。其中的第9章详细讲解了防火墙的原理与配置方式。html

基础知识

Linux系统内核内建了netfilter防火墙机制。Netfilter(数据包过滤机制),所谓的数据包过滤,就是分析进入主机的网络数据包,将数据包的头部数据提取出来进行分析,以决该链接为放行或阻挡的机制。Netfilter提供了iptables这个程序来做为防火墙数据包过滤的命令。Netfilter是内建的,效率很是高。服务器

咱们能够经过iptables命令来设置netfilter的过滤机制。网络

iptables里有3张表:tcp

> Filter(过滤器),进入Linux本机的数据包有关,是默认的表。
> NAT(地址转换),与Linux本机无关,主要与Linux主机后的局域网内计算机相关。
> Mangle(破坏者),这个表格主要是与特殊的数据包的路由标志有关(一般不用涉及到这个表的修改,对这个表的修改破坏性很大,慎改之)。spa


每张表里都还有多条链:htm

Filter:INPUT, OUTPUT, FORWARD
NAT:PREROUTING, POSTROUTING, OUTPUT
Mangle:PREROUTING, OUTPUT, INPUT, FORWARDblog


以下为iptables内建各表与链的相关性
接口

当一个数据包转给Netfilter后,Netfilter会按上面的流程依次比对每一张表。若是数据包符合表中所述,则进行相应的处理。ip


iptables命令的使用

基本格式:iptables [-t table] -CMD chain CRETIRIA -j ACTION路由

-t table:3张表中的其中一种filter, nat, mangle,若是没有指定,默认是filter。
CMD:操做命令。查看、添加、替换、删除等。
chain:链。指定是对表中的哪条链进行操做,如filter表中的INPUT链。
CRETIRIA:匹配模式。对要过滤的数据包进行描述
ACTION:操做。接受、拒绝、丢弃等。


查看

格式:iptables [-t table] -L [-nv]


修改

添加

格式:iptables [-t table] -A chain CRETIRIA -j ACTION

将新规则加入到表table(默认filter)的chain链的最后位置


插入

格式:iptables [-t table] -I chain pos CRETIRIA -j ACTION

将新规则插入到table表(默认filter)chain链的pos位置。原来以后的规则都日后推一位。pos的有效范围为:1 ~ num+1


替换

格式:iptables [-t table] -R chain pos CRETIRIA -j ACTION

用新规则替换table表(默认filter)chain链的pos位置的规则。pos的有效范围为:1 ~ num


删除

格式:iptables [-t table] -D chain pos

删除table表(默认filter)chain链的pos位置的规则。pos的有效范围为:1 ~ num


包匹配(CRETIRIA)

上面没有介绍CRETIRIA的规则,在这小节里详细介绍。包匹配就是用于描述须要过滤的数据包包头特殊的字段。

指定网口:

  -i :数据包所进入的那个网络接口,例如 eth0、lo等,需与INPUT链配合
  -o: 数据包所传出的那么网络接口,需与OUTPUT链配合

指定协议:

  -p:tcp, udp, icmp或all

指定IP网络:

  -s:来源网络。能够是IP或网络
       IP: 192.168.0.100
       网络: 192.168.0.0/24 或 192.168.0.0/255.255.255.0 都可
       能够在前加 ! 表示取反

  -d:目标网格。同 -s

指定端口:

  --sport:指定来源端口。能够是单个端口,还能够是连续的端口,例如:1024:65535。

  --dport:指定目标端口。同--sport

  注意:要指定了tcp或udp协议才会有效。

指定MAC地址:

  -m mac --mac-source aa:bb:cc:dd:ee:ff

指定状态:

  -m state --state STATUS

   STATUS能够是:

   > INVALID,无效包
   > ESTABLISHED,已经链接成功的链接状态
   > NEW,想要新立链接的数据包
   > RELATED,这个数据包与主机发送出去的数据包有关,(最经常使用)

例如:只要已创建链接或与已发出请求相关的数据包就予以经过,不合法数据包就丢弃

  -m state --state RELATED,ESTABLISHED


ICMP数据比对

ping操做发送的是ICMP包,若是不想被ping到,就能够拒绝。

  --icmp-type TYPE

  TYPE以下:

    8    echo-request(请求)
    0    echo-reply(响应)

  注意:须要与 -p icmp 配合使用。


操做(ACTION)

  DROP,丢弃

  ACCEPT,接受

  REJECT,拒绝

  LOG,跟踪记录,将访问记录写入 /var/log/messages


保存配置

将新设置的规则保存到文件

格式:iptables-save [-t table]

将当前的配置保存到 /etc/sysconfig/iptables


其它

格式:iptables [-t table] [-FXZ]

  -F :请除全部的已制订的规则
  -X :除掉全部用户“自定义”的chain
  -Z :将全部的统计值清0

 

参考文章

应用实例:http://www.cnblogs.com/JemBai/archive/2009/03/19/1416364.html

相关文章
相关标签/搜索