位置: 编程技术 - 正文

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

  • 什么公司需要缴纳印花税
  • 小饭店税务登记证办理流程
  • 复合计征消费税例题
  • 营业外收入影响所有者权益吗
  • 销售额负数怎么报税
  • 账实不符如何调平
  • 诉讼财产保全保险费计算
  • 营业执照的注册地址怎么填
  • 股东变动及股东情况章节
  • 核定征收的公司用做账么
  • 企业试生产期间发生的费用怎么入账
  • 信用卡消费凭证
  • 分公司给总公司管理费的会计分录
  • 当月认证下月抵扣
  • 赎回公司发行的债券怎么做账?
  • 资产负债率是什么之比
  • 不能取得发票的财务费用怎么做明细好一点
  • php上传文件参考文件类型
  • win10商店如何改地区
  • 前端数据统计图
  • 预提土增税账务处理
  • 关于扩展检索,下列说法正确的是
  • 增值税核算账务处理办法
  • uniapp示例
  • elemental ui
  • uniapp 手写识别
  • web前端开发 vue
  • 税前弥补以前年度亏损
  • 预付卡销售可以报销吗
  • tftp传输命令
  • python偏函数理解
  • 新会计准则增加了哪些科目
  • 科目汇总表一张不够怎么写下一页
  • 不免征个人所得税的是个人转让著作权所得
  • 捐赠合同模板
  • 网上报税优点与缺点
  • python中的threading模块
  • 个人代工程发票要缴纳的个税
  • 开具增值税专用发票是什么意思
  • 劳动仲裁的调解书可以撤销吗
  • 残保金账务处理会计科目
  • 企业所得税征前还是征后
  • 销售返利可以计入销售费用吗
  • 贷款转入账号
  • 车费属于什么会计科目类
  • 票折费用是什么意思
  • 全国统一电子发票查询
  • 为什么工程施工图纸不能泄露
  • 购买的垃圾袋计入什么科目
  • 支票有效期过期了怎么办
  • 其他商业项目
  • 委托收款商业汇票
  • Transact_SQL 小手册
  • 数据库时区与url连接设置的时区
  • centos下安装虚拟机
  • win8创建密码
  • 逼死win8的节奏 Win7升级至Win9仅需30美元 自动升级不需要重新安装
  • mac osx 10.8
  • scrtkfg.exe - scrtkfg是什么进程 有什么用
  • win10系统中怎么安装安卓应用
  • win8设备安装
  • windows2008无法识别usb
  • python 读中文文件
  • js基于什么语言
  • ntfs权限怎么设置
  • unity项目怎么运行
  • python redis hmset
  • jquery.ui
  • jquery的动画效果
  • unity getint
  • vue用户权限解决方案
  • js debounce实现
  • 深入理解javascript特性.pdf
  • BootStrap glyphicon图标无法显示的解决方法
  • 你知道什么是布
  • python流数据
  • 北京户籍网官方网站
  • 国税和地税比例
  • 登录上海电子税务局单位社保查询不到当月未交的
  • 苏州汇川和深圳汇川那个好
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设