位置: 编程技术 - 正文

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

  • 小规模缴纳企业所得税会计分录
  • 认缴制股权转让印花税的计税依据是什么
  • 股份有限公司董事会决议必须经过
  • 职工薪酬实际金额包括发放往年工资吗
  • 工程结算成本和合同成本区别
  • 什么企业可以开增值税专用发票
  • 季末资产总额的计算
  • 自然人城建税减半征收
  • 民非组织捐赠收入免税
  • 租了房子再转租
  • 货币资金包括应收票据和应收账款吗
  • 在建工程进项税额分两年抵扣
  • 劳服企业可以安差额税上税吗?
  • 股东借款可以免增值税吗
  • 经济纠纷的解决途径包括哪些
  • 砂石加工行业交什么税
  • 同一地级行政区怎么划分
  • 跨年租金收入会计分录
  • 受赠资产的价值和由捐赠企业负担的增值税
  • 个税申报系统在哪里撤销更正
  • 外币结算方式有哪几种
  • 哪些记账凭证
  • 金蝶现金流量表附表项目如何指定
  • 增值税普通发票和专用发票有什么区别
  • 先收钱后开票怎么做分录
  • linux系统中怎么编辑文件
  • win11任务栏失灵
  • PHP:xml_get_current_line_number()的用法_XML解析器函数
  • 要求快速启动
  • php字符串赋值
  • 微软win11预览版
  • vue public assets
  • vue父组件引入子组件
  • 笑脸热气球 (© Leonsbox/Getty Images Plus)
  • 公司与公司的往来款清帐需要交税吗
  • php判断useragent
  • python 命令行参数解析
  • nodejs如何与前端交互
  • transformer for
  • 员工持股平台合伙企业
  • 现金零星支出大还是小
  • 债券发行费用计入科目
  • 帝国cms视频教程
  • 兼职人员的差旅费
  • 企业残保金该什么时间交
  • 建筑公司收到劳务发票会计分录
  • 资本公积可以转增资本因此称之为准资本
  • 独资企业的税收政策
  • 出口不报关怎么收款
  • 事业单位收到退税账务处理
  • 结转本月收支
  • 新公司几个月不报税
  • 企业发生的各项罚款收入应计入
  • 工程款开票数量和单价要填吗
  • 电子承兑到期怎么申请付款
  • 结构性存款怎么计算收益
  • 期末计提利息怎么算
  • 税务人员如何做好本职工作
  • 损益表格式 最新
  • mysql5.7.29安装
  • 数据库left joins
  • mysql多字段数据
  • slmgr.vbs /dli
  • windows8.1右下角水印
  • win10服务出现了问题
  • 移动硬盘中安装系统
  • linux的tar命令用法
  • linux 系统查看
  • kpupgrader.exe是什么
  • win7arm
  • w10怎么usb连接上网
  • 宽带连接错误628win10
  • javascriptcsdn
  • domcer下载
  • js文本框只能输入字母
  • 电子发票查询官网入口
  • 如何查询汽车发票
  • 已抵扣过进项税额的固定资产改变用途
  • 2023河南新农合截止日期新规
  • 个体工商户 浙江
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设