iptables学习笔记(一)

一、iptables 的历史以及工作原理

        iptables的前身叫ipfirewall (内核1.x时代),这是一个作者从freeBSD上移植过来的,能够工作在内核当中的,对数据包进行检测的一款简易访问控制工具。但是ipfirewall工作功能极其有限(它需要将所有的规则都放进内核当中,这样规则才能够运行起来,而放进内核,这个做法一般是极其困难的)。当内核发展到2.x系列的时候,软件更名为ipchains,它可以定义多条规则,将他们串起来,共同发挥作用,而现在,它叫做iptables,可以将规则组成一个列表,实现绝对详细的访问控制功能。

        他们都是工作在用户空间中,定义规则的工具,本身并不算是防火墙。它们定义的规则,可以让在内核空间当中的netfilter来读取,并且实现让防火墙工作。而放入内核的地方必须要是特定的位置,必须是tcp/ip的协议栈经过的地方。而这个tcp/ip协议栈必须经过的地方,可以实现读取规则的地方就叫做 netfilter.(网络过滤器)。

    简而言之:iptables:是处于用户空间的,给开发人员的接口。

                    netfilter:是处于内核空间中的真正工作的防火墙。

用户通过iptables来配置netfilter。

 

    作者一共在内核空间中选择了5个位置:

    1.内核空间中:从一个网络接口进来,到另一个网络接口去的  FORWARD

    2.数据包从内核流入用户空间的 INPUT

    3.数据包从用户空间流出的 OUTPUT

    4.进入/离开本机的外网接口 PREROUTING

    5.进入/离开本机的内网接口 POSTROUTING

二、iptables的命令规则

        iptables定义规则的方式比较复杂

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

-t table: filter nat mangle

COMMAND:定义对规则如何管理

chain:指定你接下来的规则到底是在哪个链上操作的,当定义策略的时候,是可以省略的

CRETIRIA:指定匹配标准

-j ACTION :指定如何进行处理

比如:不允许172.16.0.0/24的进行访问。

 iptables -t filter -A INPUT -s 172.16.0.0/16 -p udp --dport 53 -j DROP

 当然你如果想拒绝的更彻底:

 iptables -t filter -R INPUT 1 -s 172.16.0.0/16 -p udp --dport 53 -j REJECT

iptables -L -n -v #查看定义规则的详细信息

三、详解COMMAND:

1.链管理命令(这都是立即生效的)

    -P :设置默认策略的(设定默认门是关着的还是开着的)

        默认策略一般只有两种

        iptables -P INPUT (DROP|ACCEPT)  默认是关的/默认是开的

        比如:

        iptables -P INPUT DROP 这就把默认规则给拒绝了。并且没有定义哪个动作,所以关于外界连接的所有规则包括Xshell连接之类的,远程连接都被拒绝了。

        -F: FLASH,清空规则链的(注意每个链的管理权限)

        iptables -t nat -F PREROUTING

        iptables -t nat -F 清空nat表的所有链

        -N:NEW 支持用户新建一个链

            iptables -N inbound_tcp_web 表示附在tcp表上用于检查web的。

        -X: 用于删除用户自定义的空链

            使用方法跟-N相同,但是在删除之前必须要将里面的链给清空昂了

        -E:用来Rename chain主要是用来给用户自定义的链重命名

            -E oldname newname

         -Z:清空链,及链中默认规则的计数器的(有两个计数器,被匹配到多少个数据包,多少个字节)

            iptables -Z :清空

 

2.规则管理命令

         -A:追加,在当前链的最后新增一个规则

         -I num : 插入,把当前规则插入为第几条。

            -I 3 :插入为第三条

         -R num:Replays替换/修改第几条规则

            格式:iptables -R 3 …………

         -D num:删除,明确指定删除第几条规则

        

3.查看管理命令 “-L”

     附加子命令

     -n:以数字的方式显示ip,它会将ip直接显示出来,如果不加-n,则会将ip反向解析成主机名。

     -v:显示详细信息

     -vv

     -vvv :越多越详细

     -x:在计数器上显示精确值,不做单位换算

     --line-numbers : 显示规则的行号

     -t nat:显示所有的关卡的信息

五:详解匹配标准

 

1.通用匹配:源地址目标地址的匹配

 -s:指定作为源地址匹配,这里不能指定主机名称,必须是IP

IP | IP/MASK | 0.0.0.0/0.0.0.0

而且地址可以取反,加一个“!”表示除了哪个IP之外

 -d:表示匹配目标地址

 -p:用于匹配协议的(这里的协议通常有3种,TCP/UDP/ICMP)

 -i eth0:从这块网卡流入的数据

流入一般用在INPUT和PREROUTING上

 -o eth0:从这块网卡流出的数据

流出一般在OUTPUT和POSTROUTING上

        

2.扩展匹配

2.1隐含扩展:对协议的扩展

    -p tcp :TCP协议的扩展。一般有三种扩展

--dport XX-XX:指定目标端口,不能指定多个非连续端口,只能指定单个端口,比如

--dport 21  或者 --dport 21-23 (此时表示21,22,23)

--sport:指定源端口

--tcp-fiags:TCP的标志位(SYN,ACK,FIN,PSH,RST,URG)

    对于它,一般要跟两个参数:

1.检查的标志位

2.必须为1的标志位

--tcpflags syn,ack,fin,rst syn   =    --syn

表示检查这4个位,这4个位中syn必须为1,其他的必须为0。所以这个意思就是用于检测三次握手的第一次包的。对于这种专门匹配第一包的SYN为1的包,还有一种简写方式,叫做--syn

    -p udp:UDP协议的扩展

        --dport

        --sport

    -p icmp:icmp数据报文的扩展

        --icmp-type:

echo-request(请求回显),一般用8 来表示

所以 --icmp-type 8 匹配请求回显数据包

echo-reply (响应的数据包)一般用0来表示

                  

2.2显式扩展(-m)

     扩展各种模块

      -m multiport:表示启用多端口扩展

      之后我们就可以启用比如 --dports 21,23,80

                  

        

六:详解-j ACTION

 

 常用的ACTION:

 DROP:悄悄丢弃

一般我们多用DROP来隐藏我们的身份,以及隐藏我们的链表

 REJECT:明示拒绝

 ACCEPT:接受

custom_chain:转向一个自定义的链

 DNAT

 SNAT

 MASQUERADE:源地址伪装

 REDIRECT:重定向:主要用于实现端口重定向

 MARK:打防火墙标记的

 RETURN:返回

在自定义链执行完毕后使用返回,来返回原规则链。

转载于:https://my.oschina.net/u/3240663/blog/862898

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值