iptables命令使用详解

iptables的主要功能是实现对网络数据包进出设备及转发的控制。当数据包需要进入设备、从设备中流出或者经该设备转发、路由时,都可以使用iptables进行控制。

环境
操作系统:CentOS7.3

ip地址:172.16.55.7

1.iptables中的“四表五链”及“堵通策略”
A.“四表”是指,iptables的功能——filter, nat, mangle, raw.

filter, 控制数据包是否允许进出及转发(INPUT、OUTPUT、FORWARD),可以控制的链路有input, forward, output

nat, 控制数据包中地址转换,可以控制的链路有prerouting, input, output, postrouting

mangle,修改数据包中的原数据,可以控制的链路有prerouting, input, forward, output, postrouting

raw,控制nat表中连接追踪机制的启用状况,可以控制的链路有prerouting, output

注:在centos7中,还有security表,不过这里不作介绍

B.“五链”是指内核中控制网络的NetFilter定义的五个规则链,分别为

PREROUTING, 路由前

INPUT, 数据包流入口

FORWARD, 转发管卡

OUTPUT, 数据包出口

POSTROUTING, 路由后

C.堵通策略是指对数据包所做的操作,一般有两种操作——“通(ACCEPT)”、“堵(DROP)”,还有一种操作很常见REJECT.

谈谈REJECT和DROP之间的区别,Ming写了一封信,向Rose示爱。Rose如果不愿意接受,她可以不回应Ming,这个时候Ming不确定Rose是否接到了信;Rose也可以同样写一封信,在信中明确地拒绝Ming。前一种操作就如同执行了DROP操作,而后一种操作就如同REJECT操作。

2.iptables命令的语法规则
iptables [-t table] COMMAND [chain] CRETIRIA -j ACTION
  -t table,是指操作的表,filter、nat、mangle或raw, 默认使用filter

COMMAND,子命令,定义对规则的管理

chain, 指明链路

CRETIRIA, 匹配的条件或标准

ACTION,操作动作

例如,不允许10.8.0.0/16网络对80/tcp端口进行访问,

iptables -A INPUT -s 10.8.0.0/16 -d 172.16.55.7 -p tcp --dport 80 -j DROP
  查看iptables列表

iptables -nL

3.链管理
  -N, --new-chain chain:新建一个自定义的规则链;

-X, --delete-chain [chain]:删除用户自定义的引用计数为0的空链;

-F, --flush [chain]:清空指定的规则链上的规则;

-E, --rename-chain old-chain new-chain:重命名链;

-Z, --zero [chain [rulenum]]:置零计数器;

-P, --policy chain target, 设置链路的默认策略

4.规则管理
  -A, --append chain rule-specification:追加新规则于指定链的尾部;

-I, --insert chain [rulenum] rule-specification:插入新规则于指定链的指定位置,默认为首部;

-R, --replace chain rulenum rule-specification:替换指定的规则为新的规则;

-D, --delete chain rulenum:根据规则编号删除规则;

5.查看规则 
  -L, --list [chain]:列出规则;

-v, --verbose:详细信息;

-vv, -vvv 更加详细的信息
  -n, --numeric:数字格式显示主机地址和端口号;

-x, --exact:显示计数器的精确值;

–line-numbers:列出规则时,显示其在链上的相应的编号;

-S, --list-rules [chain]:显示指定链的所有规则;

查看规则的一般内容:

6.匹配条件
匹配条件包括通用匹配条件和扩展匹配条件。

通用匹配条件是指针对源地址、目标地址的匹配,包括单一源IP、单一源端口、单一目标IP、单一目标端口、数据包流经的网卡以及协议。

扩展匹配条件指通用匹配之外的匹配条件。

6.1通用匹配条件

[!] -s, --source address[/mask][,…]:检查报文的源IP地址是否符合此处指定的范围,或是否等于此处给定的地址;

[!] -d, --destination address[/mask][,…]:检查报文的目标IP地址是否符合此处指定的范围,或是否等于此处给定的地址;

[!] -p, --protocol protocol:匹配报文中的协议,可用值tcp, udp, udplite, icmp, icmpv6,esp, ah, sctp, mh 或者 “all”, 亦可以数字格式指明协议;
[!] -i, --in-interface name:限定报文仅能够从指定的接口流入;only for packets entering the INPUT, FORWARD and PREROUTING chains.

[!] -o, --out-interface name:限定报文仅能够从指定的接口流出;for packets entering the FORWARD, OUTPUT and POSTROUTING chains.

6.2扩展匹配条件

隐含扩展匹配条件
-p tcp:可直接使用tcp扩展模块的专用选项;
  [!] --source-port,–sport port[:port] 匹配报文源端口;可以给出多个端口,但只能是连续的端口范围 ;

[!] --destination-port,–dport port[:port] 匹配报文目标端口;可以给出多个端口,但只能是连续的端口范围 ;

[!] --tcp-flags mask comp 匹配报文中的tcp协议的标志位;Flags are: SYN ACK FIN RST URG PSH ALL NONE;
    mask:要检查的FLAGS list,以逗号分隔;
    comp:在mask给定的诸多的FLAGS中,其值必须为1的FLAGS列表,余下的其值必须为0;

[!] --syn: --tcp-flags SYN,ACK,FIN,RST SYN

-p udp:可直接使用udp协议扩展模块的专用选项:

[!] --source-port,–sport port[:port]

[!] --destination-port,–dport port[:port]
-p icmp
  [!] --icmp-type {type[/code]|typename}

0/0:echo reply

8/0:echo request

显式扩展匹配条件
  必须用-m option选项指定扩展匹配的类型,常见的有以下几种,

1、multiport

以离散或连续的 方式定义多端口匹配条件,最多15个;

[!] --source-ports,–sports port[,port|,port:port]…:指定多个源端口;

[!] --destination-ports,–dports port[,port|,port:port]…:指定多个目标端口;

iptables -I INPUT -d 172.16.0.7 -p tcp -m multiport --dports 22,80,139,445,3306 -j ACCEPT

2、iprange

以连续地址块的方式来指明多IP地址匹配条件;

[!] --src-range from[-to]

[!] --dst-range from[-to]

iptables -I INPUT -d 172.16.0.7 -p tcp -m multiport --dports 22,80,139,445,3306 -m iprange --src-range 172.16.0.61-172.16.0.70 -j REJECT

3、time

匹配数据包到达的时间

–timestart hh:mm[:ss]

–timestop hh:mm[:ss]

[!] --weekdays day[,day…]

[!] --monthdays day[,day…]

–datestart YYYY[-MM[-DD[Thh[:mm[:ss]]]]]

–datestop YYYY[-MM[-DD[Thh[:mm[:ss]]]]]

–kerneltz:使用内核配置的时区而非默认的UTC;

4、string
匹配数据包中的字符

–algo {bm|kmp}

[!] --string pattern

[!] --hex-string pattern

–from offset

–to offset

~]# iptables -I OUTPUT -m string --algo bm --string “gay” -j REJECT

5、connlimit
用于限制同一IP可建立的连接数目

–connlimit-upto n

–connlimit-above n

~]# iptables -I INPUT -d 172.16.0.7 -p tcp --syn --dport 22 -m connlimit --connlimit-above 2 -j REJECT

6、limit
限制收发数据包的速率

–limit rate[/second|/minute|/hour|/day]

–limit-burst number

~]# iptables -I OUTPUT -s 172.16.0.7 -p icmp --icmp-type 0 -j ACCEPT

7、state
限制收发包的状态

[!] --state state

INVALID, ESTABLISHED, NEW, RELATED or UNTRACKED.

NEW: 新连接请求;

ESTABLISHED:已建立的连接;

INVALID:无法识别的连接;

RELATED:相关联的连接,当前连接是一个新请求,但附属于某个已存在的连接;

UNTRACKED:未追踪的连接;

state扩展:

内核模块装载:
  nf_conntrack
  nf_conntrack_ipv4

手动装载:
  nf_conntrack_ftp

追踪到的连接:
  /proc/net/nf_conntrack

调整可记录的连接数量最大值:
  /proc/sys/net/nf_conntrack_max

超时时长:
  /proc/sys/net/netfilter/timeout

iptables命令使用详解相关推荐

  1. Iptables防火墙配置详解

    iptables防火墙配置详解 iptables简介 iptables是基于内核的防火墙,功能非常强大,iptables内置了filter,nat和mangle三张表. (1)filter表负责过滤数 ...

  2. centos6.5下iptables基础知识详解与配置

    一.ipables防火墙 netfilter/iptables框架可以实现数据包过滤.网络地址转换.以及数据包管理功能 linux中的防火墙系统包括两部分:netfilter和iptables.net ...

  3. linux下防火墙iptables用法规则详解

    linux下防火墙iptables用法规则详解 分享者: du52.com 邮件: wangaibo168@163.com 主页: http://www.du52.com linux下防火墙iptab ...

  4. linux tftp客户端安装命令,Linux系统中tftp命令使用详解

    Linux系统中tftp命令主要是传输文件用的.下面由学习啦小编为大家整理了linux系统中tftp命令使用详解,希望对大家有帮助! Linux系统中tftp命令使用详解 语法 tftp [主机名称或 ...

  5. Iptables防火墙策略详解

    Iptables防火墙策略详解 一.iptables Linux 系统的防火墙--netfilter/iptables IP信息包过滤系统,它实际上由两个组件netfilter 和 iptables组 ...

  6. 计算机网络管理的常用命令,网络管理常用命令图文详解.pdf

    网络工程师必备 – 网络管理常用命令图文详解 网络工程师必备 网络管理常用命令 图文详解 V1.0 V1.0 包含 ping.ipconfig.netstat.nbtstat.tracert. pat ...

  7. php mysql source_Mysql数据库导入命令Source详解

    Mysql数据库导入命令Source详解 几个常用用例: 1.导出整个数据库 mysqldump -u 用户名 -p 数据库名 > 导出的文件名mysqldump -u root -p data ...

  8. mkdir命令使用详解

    linux下mkdir命令使用详解---linux下创建目录命令 时间:2010-06-03 21:46来源:未知 作者:Linux安全网 点击: 957次 linux mkdir命令: 创建目录 介 ...

  9. Linux 执行文件查找命令 which 详解

    某个文件不知道放在哪里了,通常可以使用下面的一些命令来查找: which  查看可执行文件的位置 whereis 查看文件的位置 locate   配合数据库查看文件位置 find   实际搜寻硬盘查 ...

最新文章

  1. php要怎么使用imagettftext_延长防腐木使用要怎么做呢?
  2. atitit.mp4 视频文件多媒体格式结构详解
  3. 给UIScrollView添加category实现UIScrollView的轮播效果
  4. Matlab计算多项式的值(数值)
  5. java计算两地距离(公里)
  6. HTTP Request Content-Type:application/x-www-form-urlencoded、multipart/form-data、application/json
  7. 一些有趣的三方开源库
  8. 洛谷P3195 [HNOI2008]玩具装箱TOY
  9. vue的双向绑定原理及实现
  10. 3、C#面向对象:封装、继承、多态、String、集合、文件(下)
  11. 任何举动之前,先思考,思考,再思考
  12. 2017华南理工华为杯H bx值(容斥问题)
  13. Win7安装Mysql8.0步骤
  14. OPNsense用户手册-高可用性和硬件故障转移
  15. 魔兽对战平台服务器更新维护什么,官方对战平台每天5点维护是个什么梗
  16. A类博士后年薪30万起!北邮人工智能学院郭军教授实验室招聘博士后研究人员...
  17. pt-table-checksum使用总结
  18. 搜狗拼音输入法2015 v7.2f 官方版
  19. C++ 多个指针指向同一个对象
  20. JDK、JRE、JVM、SDK

热门文章

  1. C语言 万年历 C语言 万年历
  2. OpenCV显示中文汉字,未使用CvxText和FreeType库,很强大!!
  3. 五子棋——沈航2017年计算机博弈国赛代码解析
  4. HTML中的字体与文本
  5. 2023南京师范大学中国美术史考研复习经验分享
  6. 零中频接收机频率转换图_大神告诉你WCDMA之Tx Leakage对于零中频接收机之危害
  7. 换城市为什么需要换号
  8. PHP自动批量生成发卡平台卡密信息并导入数据库
  9. Hadoop核心组件详解—HDFS、YARN、MapReduce
  10. 再读《银湖计划》---从变革管理的角度看银湖计划的成功(转)