位置: 编程技术 - 正文

构筑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防火墙的主要内容)

  • 报废的原材料
  • 个税是每个月都扣吗
  • 母公司给子公司开票会有税务风险吗
  • 政府减免税款如何账务处理
  • 展板制作费属于什么服务
  • 接受捐赠材料支付的运费 扣除
  • 在建工程购入的空调怎样入账
  • 承兑汇票转出
  • 出差补助没有发票计入什么科目
  • 给企业供货都有哪些渠道
  • 已认证的发票如何导入
  • 营改增对资产负债表的影响
  • 防暑降温需要缴什么费用
  • 劳保用品计入福利费嘛
  • 公司账上收到退回的多交的附加税怎么做
  • 会计报表上总资产怎么填
  • 理财产品取得收益要交税吗
  • 外资企业投资国内企业程序
  • 销项负数发票需要抵扣吗
  • 进口报关单是什么样子的
  • 一般纳税人有进项无销项
  • 此次新政策对原来就是小型微利企业的纳税人有影响吗?
  • 企业停产没有收入,费用可以计入长期待摊费用吗
  • 企业所得税汇算清缴扣除比例
  • win11 应用商店
  • 代理进口合同如何签署
  • php iswriteable
  • 契税发票遗失怎么处理
  • php gd库
  • 政府补贴款计入什么科目是否纳税
  • 个人抬头有什么用
  • ajax如何返回数据
  • jsonp解决跨域问题spring3.0
  • vue系列教程
  • 工程款清账的句子发朋友圈
  • 招待费超出部分的分录
  • 设备计提折旧从什么时候开始
  • MySQL主从数据库搭建
  • 农业种植会计
  • Access数据库文件以什么作为文件后缀名
  • 代理费属于
  • 做账时实收资本减少应该记在那一栏
  • 公司买车可以抵扣企业所得税吗
  • 充值卡赠送金额属于什么性质
  • 出口收汇核销单的作用
  • 购买金税盘未抵税怎么办
  • 赠送油卡需要代理吗
  • 根据企业会计准则第4号固定资产,企业可选用的折旧方法
  • 2018年水利建设基金税率
  • 如何填写记账凭证视频
  • ubuntu 14.04.6
  • windows的服务怎么打开
  • winxp怎样设置网络
  • mac刻录工具
  • linux如何安装wget命令
  • win8怎么设置桌面图标
  • app塔防游戏
  • Android游戏开发打砖块
  • linux中vi命令是什么意思
  • coco触控
  • 菜鸟学安卓逆向
  • 进入cmd命令
  • pythonlist切片
  • cocos2dx-3.2+lua 常用函数
  • jQuery中$.ajax()方法参数解析
  • shell脚本中调用外部c程序
  • jquery处理json格式数据
  • 莱鸟人集团
  • jquery showdialog
  • 运用python编写程序
  • jquery 3.5
  • android简单app实例
  • 济南税务局投诉电话
  • 怎么查询电子票是否被红冲
  • 国税新人什么时候入职
  • 职工教育经费可以结转吗
  • 医院是自给自足吗
  • 10%加计抵减政策条件
  • 公司员工开始摆烂怎么办
  • 税务局经费来源
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设