图文详解防火墙及NAT服务
《图文详解防火墙及NAT服务》要点: 一、简介1. 关于防火墙 防火墙,其实就是用于实现Linux下访问控制的功能的,它分为硬件和软件防火墙两种.无论是在哪个网络中,防火墙工作的地方一定是在网络的边缘.而我们的任务就是需要去定义到底防火墙如何工作,这就是防火墙的策略、规则,以达到让它对出入网络的IP、数据进行检测. 目前市面上比较常见的有三、四层的防火墙,叫做网络层的防火墙,还有七层的防火墙,其实是代理层的网关.对于TCP/IP的七层模型来讲,我们知道第三层是网络层,三层的防火墙会在这层对源地址和目标地址进行检测.但对于七层的防火墙,不管你源端口或者目标端口,源地址或者目标地址是什么,都将对你所有的东西进行检查.所以,对于设计原理来讲,七层防火墙更加安全,但是这却带来了效率更低.所以市面上通常的防火墙方案,都是两者相互结合的. 2. iptables的发展 包括iptables及其前身在内,这些都是工作在用户空间中,定义规则的工具,本身并不算是防火墙.它们定义的规则,并且可以让在内核空间当中的“Netfilter”来读取,从而实现让防火墙工作.而放入内核的地方必须要是特定的位置,必须是TCP/IP的协议栈所经过的地方——Netfilter. iptables只是防火墙的管理工具,在内核中真正实现防火墙功能的是Netfilter. 对Linux而言,TCP/IP协议栈存在于内核当中,这就意味着对数据报文的处理是在内核中处理的,也就是说防火墙必须在工作在内核中,防火墙必须在内核中完成TCP/IP报文所流进的位置,使用规则去检查,才真正能工作起来. 3. iptables的结构 从上面的发展我们知道了作者选择了五个位置,来作为控制的地方,但是你有没有发现,其实前三个位置已经基本上能将路径彻底封锁了,但是为什么已经在进出的口设置了关卡之后还要在内部设置关卡呢?由于数据包尚未进行路由决策,还不知道数据要走向哪里,所以在进出口是没有办法实现数据过滤的.所以要在内核空间里设置转发的关卡,进入用户空间的关卡,从用户空间出去的关卡.那么,既然他们没有什么用,我们为什么还要放置他们呢?因为在进行NAT/DNAT的情况下,目标地址转换必须在路由之前转换.所以我们必须在外网而后内网的接口处进行设置关卡. iptable的结构:在数据包过滤表中,规则被分组放在我们所谓的链中.链,就是一个规则的列表(如图所示). 二、表和链要设置一个Linux防火墙,就要使用规则,每个规则指定在包中与什么匹配,以及对包执行什么操作.那么什么是规则呢?因为iptables利用的是数据包过滤的机制,所以它会分析数据包的报头数据.根据报头数据与定义的规则来决定该数据包是否可以通过或者是被丢弃.也就是说,根据数据包的分析资料来与预先定义的规则内容进行“比对”,若数据包数据与规则内容相匹配则进行相应的处理,否则就继续下一条规则的比对.重点在于比对与比对的顺序. 什么是表和链呢?这得由iptables的名称说起,为什么称为iptables呢?因为它里面包含有多个表格(table),每个表格都定义出自己的默认策略与规则,且每个表格的用途都不相同.iptables包含四个表,五个链.其中表是按照对数据包的处理功能区分的,链是按照不同的Hook点来区分的,表和链实际上是netfilter的两个维度. 四个规则表分别为:Filter、NAT、Mangle、Raw,默认表是Filter(没有指定表的时候就是Filter表). 表的处理优先级为:Raw>Mangle>NAT>Filter 常用的三个表: 三、工作流程iptables采用的是数据包过滤机制工作的,所以它会对数据包的报头信息进行分析,并根据我们预先设定的规则进行匹配来决定是否对数据包的处理方式. 防火墙是层层过滤的,实际是按照匹配规则的顺序从上到下,从前到后进行过滤的.如果匹配上规则,即明确表明是阻止还是通过,数据包就不在向下继续进行匹配了.如果规则中没有明确判断出处理结果,也就是说不匹配当前规则,那么就继续向下进行匹配,直到匹配默认的规则,得到最后的处理结果.所以说规则的顺序至关重要. 防火墙的默认规则是所有的规则均不匹配时,才会执行的规则. 指令常用操作选项: 常用封包比对参数: 其它选项: 操作实例:禁止SSH远程登录 注意:通过命令行添加的防火墙指令仅仅是临时生效的,系统重启即失效. 处理动作包括: 指令格式示意图: 两种增加规则选项的差别: -A chain rule-specification:添加规则到指定规则链的结尾,成为最后一条规则. -I chain [rulenum] rule-specification:如果没有指定序号,则添加的规则将成为对应链中的第一条规则.如果指定了序号,则成为该序号上的规则,而原来位于该序号的规则将往后移一位. 操作实例:禁止PING本机(ping指令属于ICMP协议,其类型为“8”) 四、企业案例1. 配置案例讲解 (编辑:ASP站长网) |