码迷,mamicode.com
首页 > 系统相关 > 详细

Linux下防火墙iptables设置

时间:2014-09-13 21:36:56      阅读:401      评论:0      收藏:0      [点我收藏+]

标签:style   http   io   os   使用   ar   strong   for   文件   

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

基础知识

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

我们可以通过iptables命令来设置netfilter的过滤机制。

iptables里有3张表:

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


每张表里都还有多条链:

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


如下为iptables内建各表与链的相关性

bubuko.com,布布扣

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


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] -R 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


Linux下防火墙iptables设置

标签:style   http   io   os   使用   ar   strong   for   文件   

原文地址:http://my.oschina.net/hevakelcj/blog/313212

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!