位置: 编程技术 - 正文

构筑Linux防火墙之IPtables的概念与用法(1)(linux 防火墙原理)

编辑:rootadmin

推荐整理分享构筑Linux防火墙之IPtables的概念与用法(1)(linux 防火墙原理),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:linux 防火墙原理,linux防火墙的组成包括,linux防火墙规则设置,linux 防火墙原理,linux防火墙的主要内容,linux防火墙工作原理,linux 防火墙原理,linux防火墙的设计与实现,内容如对您有帮助,希望把文章链接给更多的朋友!

构筑Linux防火墙之什么是Linux防火墙防火墙典型的设置是有两个网卡,一个流入,一个流出。iptables读取流入和流出的数据包的报头,然后将它们与规划集(ruleset)相比较,然后将可接受的数据包从一个网卡转发至另外一个网卡。对于被拒绝的数据包,可以被丢弃或者按照你所定义的方式来处理。通过向防火墙提供有关对来自某个源、到某个目的地或具有特定协议类型的信息包要做些什么的指令的规则,控制信息包的过滤。通过使用iptables系统提供的特殊命令 iptables,建立这些规则,并将其添加到内核空间的特定信息包过滤表内的链中。关于添加、除去、编辑规则的命令的一般语法如下:

构筑Linux防火墙之IPtables的概念与用法(1)(linux 防火墙原理)

iptables [-t table] command [match] [target]   

现实中,为了易读,我们一般都用这种语法。大部分规则都是按这种语法写的,因此,如果看到别人写的规则,你很可能会发现用的也是这种语法。 如果不想用标准的表,就要在[table]处指定表名。一般情况下没有必要指定使用的表,因为iptables 默认使用filter表来执行所有的命令。也没有必要非得在这里指定表名,实际上几乎可在规则的任何地方指定表名。当然,把表名放在开始处已经是约定俗成的标准。尽管命令总是放在开头,或者是直接放在表名后面,我们也要考虑到底放在哪儿易读。 “command”告诉程序该做什么,比如:插入一个规则,还是在链的末尾增加一个规则,还是删除一个规则。下面会仔细地介绍。 “match”细致地描述了包的某个特点,以使这个包区别于其它所有的包。在这里,我们可以指定包的来源IP 地址、网络接口、端口、协议类型,或者其他什么。下面我们将会看到许多不同的match。 最后是数据包的目标所在“target”。若数据包符合所有的match,内核就用target来处理它,或者说把包发往target。比如,我们可以让内核把包发送到当前表中的其他链(可能是我们自己建立的),或者只是丢弃这个包而不做任何处理,或者向发送者返回某个特殊的应答。下面我们来逐个讨论这些选项:

表(table)[-t table]选项允许使用标准表之外的任何表。表是包含仅处理特定类型信息包的规则和链的信息包过滤表。有三种可用的表选项:filter、nat 和 mangle。该选项不是必需的,如果未指定,则filter用作缺省表。下面介绍各表实现的功能。filterfilter 表用来过滤数据包,我们可以在任何时候匹配包并过滤它们。我们就是在这里根据包的内容对包做DROP或ACCEPT的。当然,我们也可以预先在其他地方做些过滤,但是这个表才是设计用来过滤的。几乎所有的target都可以在这儿使用。natnat表的主要用处是网络地址转换,即Network Address Translation,缩写为NAT。做过NAT操作的数据包的地址就被改变了,当然这种改变是根据我们的规则进行的。属于一个流的包只会经过这个表一次。如果第一个包被允许做NAT或Masqueraded,那么余下的包都会自动地被做相同的操作。也就是说,余下的包不会再通过这个表,一个一个的被NAT,而是自动地完成。这就是我们为什么不应该在这个表中做任何过滤的主要原因。PREROUTING 链的作用是在包刚刚到达防火墙时改变它的目的地址,如果需要的话。OUTPUT链改变本地产生的包的目的地址。POSTROUTING链在包就要离开防火墙之前改变其源地址此表仅用于NAT,也就是转换包的源或目标地址。注意,只有流的第一个包会被这个链匹配,其后的包会自动被做相同的处理。实际的操作分为以下几类:◆ DNAT◆ SNAT◆ MASQUERADEDNAT操作主要用在这样一种情况,你有一个合法的IP地址,要把对防火墙的访问 重定向到其他的机子上(比如DMZ)。也就是说,我们改变的是目的地址,以使包能重路由到某台主机。 SNAT改变包的源地址,这在极大程度上可以隐藏你的本地网络或者DMZ等。一个很好的例子是我们知道防火墙的外部地址,但必须用这个地址替换本地网络地址。有了这个操作,防火墙就 能自动地对包做SNAT和De-SNAT(就是反向的SNAT),以使LAN能连接到Internet。如果使用类似 ..0.0/这样的地址,是不会从Internet得到任何回应的。因为IANA定义这些网络(还有其他的)为私有的,只能用于LAN内部。MASQUERADE的作用和MASQUERADE完全一样,只是计算机 的负荷稍微多一点。因为对每个匹配的包,MASQUERADE都要查找可用的IP地址,而不象SNAT用的IP地址是配置好的。当然,这也有好处,就是我们可以使用通过PPP、 PPPOE、SLIP等拨号得到的地址,这些地址可是由ISP的DHCP随机分配的。Mangle这个表主要用来mangle数据包。我们可以改变不同的包及包头的内容,比如 TTL,TOS或MARK。 注意MARK并没有真正地改动数据包,它只是在内核空间为包设了一个标记。防火墙内的其他的规则或程序(如tc)可以使用这种标记对包进行过滤或高级路由。这个表有五个内建的链: PREROUTING,POSTROUTING, OUTPUT,INPUT和 FORWARD。PREROUTING在包进入防火墙之后、路由判断之前改变包,POSTROUTING是在所有路由判断之后。 OUTPUT在确定包的目的之前更改数据包。INPUT在包被路由到本地之后,但在用户空间的程序看到它之前改变包。注意,mangle表不能做任何NAT,它只是改变数据包的TTL,TOS或MARK,而不是其源目的地址。NAT是在nat表中操作的,以下是mangle表中仅有的几种操作:◆ TOS◆ TTL◆ MARKTOS操作用来设置或改变数据包的服务类型域。这常用来设置网络上的数据包如何被路由等策略。 注意这个操作并不完善,有时得不所愿。它在Internet上还不能使用,而且很多路由器不会注意到这个域值。换句话说,不要设置发往Internet的包,除非你打算依靠TOS来路由,比如用iproute2。TTL操作用来改变数据包的生存时间域,我们可以让所有数据包只有一个特殊的TTL。它的存在有一个很好的理由,那就是我们可以欺骗一些ISP。为什么要欺骗他们呢?因为他们不愿意让我们共享 一个连接。那些ISP会查找一台单独的计算机是否使用不同的TTL,并且以此作为判断连接是否被共享的标志。MARK用来给包设置特殊的标记。iproute2能识别这些标记,并根据不同的标记(或没有标记) 决定不同的路由。用这些标记我们可以做带宽限制和基于请求的分类。

构筑Linux防火墙之IPtables的概念与用法(2) 目标(target)我们已经知道,目标是由规则指定的操作,那些与规则匹配的信息包执行这些操作。除了允许用户定义的目标之外,还有许多可用的目标

Linux架设DNS服务器(一) 一、域名系统介绍1.域名系统域名系统为一个分布式数据库,它使本地负责控制整个分布式数据库的部分段,每一段中的数据通过客户,服务器模式在整个网

Linux架设DNS服务器(二) 2.安装服务器软件2.1取得bind软件包(现在新的版本为8.2.2p5)从bind的主页

标签: linux 防火墙原理

本文链接地址:https://www.jiuchutong.com/biancheng/366237.html 转载请保留说明!

上一篇:和大家一起分享不错的iptables(和大家一起分享一下你读书以后的感受吧)

下一篇:构筑Linux防火墙之IPtables的概念与用法(2)(linux防火墙的主要内容)

  • 车船税是每个月交还是每年交
  • 公司的纳税人识别号怎么查询
  • 购买冰箱微波炉注意事项
  • 所得税多交退税分录
  • 税金及附加现金流指定
  • 如何证明自己是低保户
  • 工资发放凭证由谁出具
  • 商贸企业增值税优惠政策
  • 出售旧固定资产的税率是多少
  • 企业所得税成本确认原则
  • 国外劳务费用是怎样产生的
  • 企业账户短信提醒可以用别人手机号吗
  • 房地产企业所得税预缴
  • 金税盘提示离线开票时间超限深圳
  • 维修服务费税率是多少?
  • abs应付债券
  • 支票作废了需要什么材料
  • 高新技术企业取消资格的程序
  • 金银首饰的消费税在什么环节
  • 利润分配补亏
  • 残保金按计提数还是按发放数申报
  • 会计凭证传递的原则及基本程序
  • 递延收益的会计科目
  • windows无法连接到system Events
  • 电脑任务栏消失怎么把它显示出来
  • 如何确定我的世界的区块
  • PHP:oci_field_type_raw()的用法_Oracle函数
  • 专用发票怎样申报
  • 即征即退,先征后退,先征后返的区别?
  • php解析json对象
  • php curl命令详解
  • 在一株植物上行走的作文
  • 阿尔比恩洞的级别
  • laravel执行seed命令
  • 企业商誉属于什么资产
  • php获取指定日期的星期几的方法是
  • php中global
  • 一般纳税人增值税结转账务处理
  • 客户倒闭预收款怎么处理
  • 外贸企业出口货物增值税的计算依据
  • 企业之间的借款计入什么科目
  • 未开票交税怎么做账
  • 劳务外经证预缴税款
  • 免费开源okr管理系统
  • 外经证是啥样
  • 付国外专利费用需办什么手续
  • 关联企业债资比怎么计算
  • 土地免缴土地使用税
  • 售出货物
  • 代扣职工个人所得税的账务处理
  • 个体户4年不注销有事吗
  • 会计审计属于什么类别
  • 原始凭证书写要求
  • 工业企业材料入库账务处理
  • sql server 不存在或者拒绝访问
  • sqlserver key
  • win10 性能选项
  • windows 10 build 9888
  • bios更改
  • Win8.1 64位系统安装Office365出现30125-1011错误提示的故障原因及解决方法
  • ahqinit.exe是什么进程 ahqinit是安全的进程吗
  • linux lv vg
  • linux系统的
  • win8删除软件在哪里
  • 获取windows的最新信息
  • win10系统语言包安装方法
  • Win8出现奇怪爆音的完美解决方法
  • nodejs oom
  • unity打包package
  • 快速备份mysql数据库
  • [置顶]津鱼.我爱你
  • javascript中的107个基础知识收集整理 推荐
  • unity3d赛车游戏毕业设计
  • jquery教程chm
  • CLASS_CONFUSION JS混淆 全源码
  • js在div中添加div
  • 境外承包工程款收入
  • 财产转让所得适用税率
  • 电子专用发票怎么申请领用
  • 美国有汽车吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设