iptables 实际操作 之 规则查询 2
在之前的文章中,我们已经总结过,iptables 为我们预定义了4张表,他们分别是raw 表,mangle表,nat表,filter表,不同的表拥有不同的功能。
filter 负责过滤功能,比如允许那些IP 地址访问,拒绝那些IP地址访问,允许访问那些端口,禁止访问那些端口,filter表会根据我们定义的规则进行过滤,filter表应该是我们最常用到的表了,所以此处,我们一filter表为例,开始学习怎样实际操作iptables。
一. 查看filter 表的规则
[root@localhost ~]# iptables -t filter -L -nv --line
Chain INPUT (policy ACCEPT 78 packets, 5830 bytes)
num pkts bytes target prot opt in out source destina
tion
Chain FORWARD (policy ACCEPT 0 packets, 0 bytes)
num pkts bytes target prot opt in out source destina
tion
Chain OUTPUT (policy ACCEPT 51 packets, 5100 bytes)
num pkts bytes target prot opt in out source destina
tion
上例中我们使用 –t 选项,指定要操作的表,使用-L 选项,查看-t 选项对应的表的规则,-L选项的意思是列出规则,所以,上述命令的含义为列出filter表的所有规则。上图中显示了3条链,INPUT 链,FORWARD 链,OUTPUT 链,每条链中都有“过滤”的能力,所以,当我们要定义某条“过滤”的规则时,我们会在filter 表定义,但是具体在那条“链”上定义规则,这取决于我们的工作场景。比如,我们需要禁止某个IP地址访问我们的主机,我们则需要在INPUT 链上定义规则。因为,我们在理论总结中已经提到过,报文发往本机时,会经过PREROUTING 链于INPUT 链,所以,如果我们想要禁止某些报文发往本机,我们只能在PREROUTING链和INPUT链中定义规则,但是PREROUTING 链并不存在于filter 表中,换句话说就是,PREROUTING 关卡天生就没有过滤的能力,所以,我们只能在IPNPUT链中定义,当然,如果是其他工作场景,可能需要在FORWARD链或者OUTPUT链中定义过滤规则。其实,我们可以省略 –t filter当没有使用使用-t 选项指定表时,默认认为操作filter表,即iptables –L 表示列出filter 表中的所有规则。
我们还可以只查看指定表中的指定链的规则,如下,我们只查看filter表中的INPUT 链的规则:
[root@localhost ~]# iptables -L INPUT
Chain INPUT (policy ACCEPT)
target prot opt source destination
我们可以使用 –v 来选项,查看出更多的,更详细的信息;使用 –n 表示不对ip地址进行名称反解,直接显示IP地址,实例如下:
[root@localhost ~]# iptables -L -nv
Chain INPUT (policy ACCEPT 393 packets, 33975 bytes)
pkts bytes target prot opt in out source destination
Chain FORWARD (policy ACCEPT 0 packets, 0 bytes)
pkts bytes target prot opt in out source destination
Chain OUTPUT (policy ACCEPT 200 packets, 18176 bytes)
pkts bytes target prot opt in out source destination
pkts: 对应规则匹配到的报文的个数
bytes: 对应匹配到的报文包的大小总和
target:规则对应的target,往往表示规则对应的“动作”,即规则匹配成功后需要采取的措施。
prot:表示规则对应的协议,是否只针对某些协议应用次规则。
opt:表示规则对应的选项。
in:表示数据包由那个接口(网卡)流入,我们可以设置通过那块网卡流入的报文需要匹配当前规则。
out:表示数据包由那个接口(网卡)流出,我们可以设置通过那块网卡流出的报文需要匹配当前规则。
source:表示规则对应的源头地址,可以是一个IP,也可以是一个网段。
destination:表示规则对应的目标地址。可以是一个IP,也可以是一个网段。
使用 --line-numbers 可显示规则的编号,--line-numbers 选项可以缩写成 --line,iptables也可以识别
[root@localhost ~]# iptables -L -nv --line
Chain INPUT (policy ACCEPT 0 packets, 0 bytes)
num pkts bytes target prot opt in out source destination
1 34 2556 ACCEPT tcp -- * * 0.0.0.0/0 0.0.0.0/0 multiport dports 22
Chain FORWARD (policy ACCEPT 0 packets, 0 bytes)
num pkts bytes target prot opt in out source destination
Chain OUTPUT (policy ACCEPT 24 packets, 2256 bytes)
num pkts bytes target prot opt in out source destination
聪明的你,一定会注意到括号里的内容 policy ACCEPT packets bytes,他们表示的意思如下:
policy 表示当前链的默认策略,policy ACCEPT 表示上图中INPUT的链的默认动作为ACCEPT,换句话说就是,默认接受通过INPUT 关卡的所有请求,所以我们在配置INPUT 链的具体规则时,应该将需要拒绝的请求配置到规则中,说白了就是“黑名单”机制,默认所有人都能通过,只有指定的人不能通过,当我们把INPU 链默认动作设置为接受(ACCEPT),就表示所有人都能通过这个关卡,此时就应该在具体的规则中指定需要拒绝的请求,就 表示只有指定的人不能通过这个关卡,这就是黑名单机制,但是,你一定发现了,上图中所显示出的规则,大部分都是接受请求(ACCEPT),并不是想象中的拒绝请求(DROP或者REJECT),这与我们所描述的黑名单机制不符啊,按照道理俩说,默认动作为接受,就应该在具体的规则中配置需要拒绝的人,但是上图中并不是这样的,之所以出现上图中的情况,是因为iptables 的工作机制导致的,上例其实是利用了这些“机制”,完成了所谓的“白名单”机制,并不是我们所描述的“黑名单”。此处我们只要明白policy 对应的动作为链的默认动作即可,或者换句话说,我们只要理解,policy为链的默认策略即可。
packets 表示当前链(上例为INPUT 链)默认策略匹配到的包的数量,0 packets 表示策略匹配到0个包。
bytes 表示当前链默认策略匹配到的所有包的大小总和。
其实我们可以把packets 和bytes 称作“计数器”,上图中的计数器记录了默认策略匹配到的报文数量与总大小,“计数器”只会在使用 –v 选项时,才会显示出来。当被匹配到包达到一定数量是,计数器会自动将匹配到的包的大小转换为可读性较高的单位,如下图所示。
[root@localhost ~]# iptables -nvL INPUT
Chain INPUT (policy ACCEPT 55578 packets, 332K bytes)
如果你想要查看精确的计数值,而不是经过可读性优化过的计数值,那么你可以使用-x 选项,表示显示精确的计数值,示例如下。
[root@localhost ~]# iptables -nvxL INPUT
Chain INPUT (policy ACCEPT 380 packets, 33500 bytes)
pkts bytes target prot opt in out source destination
127 9448 ACCEPT tcp -- * * 0.0.0.0/0 0.0.0.0/0 multiport dports 22
二. 命令小结
1. iptable –t 表名 –L
查看对应表的所有规则,-t 选项指定要操作的表,省略“-t 表名” 时,默认表示操作filter表,-L 表示列出规则,即查看规则。
2. iptables –t 表名 –L 链名
查看指定表的指定链中的规则
3. iptables –t 表名 –v –L
查看指定表的所有规则,并且显示更详细的信息(更多字段),-v 表示 verbose,表示详细的,冗长的,当使用 –v 选项时,会显示出“计数器” 的信息,由于上例中使用的选项都是短选项,所以一般简写成为iptables –t 表名 –vL
4. iptables –t 表名 –n –L
表示查看表的所有规则,并且在显示规则时,不对规则中的IP 或者端口进行名称反解,-n 选项表示不解析IP 地址。
5. iptables –lin-number –t 表名 –L
表示查看表的所有规则,并且显示规则的序号,—line-numbers 选项表示显示规则的序号,注意,此选项为长选项,不能与其他短选项合并,不过此选项可以简写为 –line 注意,简写后仍然是两条横杠,仍然是长选项。
6. iptables –t 表名 –v –x –L
表示查看表中的所有规则,并且显示更详细的信息 (-v 选项),不过,计数器中的信息显示为精确的计数值,而不是显示为经过可读优化的计数值,-x 选项表示显示计数器的精确值。
7. iptables –line –t filter –nvxL
为了方便会将短选项进行合并,将选项粘合在一起,写成如上命令。
8. iptables –line –t filter –nvxL INPUT
可以只查看某张表中的某条链,此处一filter 表的INPUT 链为例
iptables 实际操作 之 规则查询 2的更多相关文章
- iptables(二)iptables实际操作之规则查询
如果你是一个新手,在阅读如下文章时,请坚持读到最后,读的过程中可能会有障碍,但是在读完以后,你会发现你已经明白了. 在进行iptables实验时,请务必在测试机上进行. 之前在iptables的概念中 ...
- iptables详解(2):iptables实际操作之规则查询
所属分类:IPtables Linux基础 在阅读这篇文章之前,请确保你已经阅读了如下文章,如下文章总结了iptables的相关概念,是阅读这篇文章的基础. 图文并茂理解iptables 如果你是一 ...
- iptables规则查询
iptables规则查询 之前在iptables的概念中已经提到过,在实际操作iptables的过程中,是以"表"作为操作入口的,如果你经常操作关系型数据库,那么当你听到" ...
- spring data jpa 使用方法命名规则查询
按照Spring Data JPA 定义的规则,查询方法以findBy开头,涉及条件查询时,条件的属性用条件关键字连接,要注意的是:条件属性首字母需大写.框架在进行方法名解析时,会先把方法名多余的前缀 ...
- SpringData_02_JPQL查询、SQL查询和方法命名规则查询
1.使用JPQL的方式查询 JPQL查询:Hibernate提供的是HQL查询,而JPA提供的是JPQL查询语言 使用Spring Data JPA提供的查询方法已经可以解决大部分的应用场景,但是对于 ...
- Android Linux自带iptables配置IP访问规则
利用Linux自带iptables配置IP访问规则,即可做到防火墙效果
- mysql 数据操作 单表查询 目录
mysql 数据操作 单表查询 mysql 数据操作 单表查询 简单查询 避免重复DISTINCT mysql 数据操作 单表查询 通过四则运算查询 mysql 数据操作 单表查询 concat()函 ...
- mysql 数据操作 多表查询 目录
mysql 数据操作 多表查询 准备 多表连接查询介绍 mysql 数据操作 多表查询 多表连接查询 笛卡尔积 mysql 数据操作 多表查询 多表连接查询 内连接 mysql 数据操作 多表查询 多 ...
- python操作oracle数据库-查询
python操作oracle数据库-查询 参照文档 http://www.oracle.com/technetwork/cn/articles/dsl/mastering-oracle-python- ...
随机推荐
- webpacke install vue application 报错 Failed at the phantomjs-prebuilt@2.1.14 install script
刚刚在网上下了个开源的项目: https://github.com/ing670/webappkiller 执行npm install 报错:npm ERR! Failed at the phanto ...
- .Net——实现IConfigurationSectionHandler接口定义处理程序处理自己定义节点
除了使用.net里面提供的内置处理程序来处理我们的自己定义节点外,我们还能够通过多种方法,来自己定义处理类处理我们的自己定义节点,本文主要介绍通过实现IConfigurationSectionHand ...
- TP视图命名规则之一
TP视图命名规则之一 如果觉得目录结构太深,可以通过设置 TMPL_FILE_DEPR 参数来配置简化模板的目录层次,例如设置: 'TMPL_FILE_DEPR'=>'_' 默认的模板文件就 ...
- wampServer(windows、apache、mysql、php)
wampServer(windows/apche/mysql/php)集成环境 在线状态:区域网内可以访问 离线状态:本地设备可以访问 自拟定网站根目录: Apache -- httpd.conf - ...
- 当执行sql更新失误,添加了错误的判断条件,导致数据表数据出错时,如何利用备份数据库实现联合更新还原数据。
首先得有备份数据库,没有备份肯定无法联合更新回复. 我错误更新了 [SBSDB].[dbo].[wallet_user_info]中的用户名user_name 我的备份数据库及对应数据表SBSDBTe ...
- Telerik UI for ASP.NET Core概要
介绍:不介绍了,刚开始研究. 下载:CSDN或者51cto上都有最新的开发版 安装:默认的安装目录是C:\Program Files (x86)\Progress\Telerik UI for ASP ...
- TFTP 与 FTP的区别
FTP(File Transfer Protocol,文件传输协议)协议在TCP/IP协议族中属于应用层协议,用于在远端服务器和本地客户端之间传输文件,使用TCP端口20和21进行传输.端口20用于传 ...
- windows操作系统记事本保存操作时间、字符映射表的打开、步骤记录器使用
记事本自动记录修改时间 你有用记事本记账或写日记的习惯吗?其实在记事本的文档开头输入".LOG"(无引号,字母为大写),之后记录内容并保存,这样以后打开就会看到之前每次修改的时间了 ...
- linux系统之free命令详解
total used free shared buffers cached Mem: -/+ buffers/cache: Swap: 上面是free命令的执行结果,下面我来详细说说其中的含义: Me ...
- Python内置函数之filter()
filter(function,iterable)用来过滤可迭代对象 如果提供过滤条件的函数为None,则可迭代对象中为False的元素将被过滤掉. 例如: >>> a = [,,F ...