参考地址

http://www.cnblogs.com/metoy/p/4320813.html

http://netfilter.org/ iptables

http://man.chinaunix.net/network/iptables-tutorial-cn-1.1.19.html

1 防火墙简介

防火墙就是用于实现访问控制功能的,分为软件和硬件两种大类,防火墙主要是基于制定的防火墙策略工作,达到对出入网络的数据进行处理。所以对于防火墙来说,重要要的是规则的配置,规则的配置在linux主要是通过iptables命令创建规则的。所以接下来重点介绍iptables的使用。

2 iptables简介

netfilter/iptables(简称为iptables)组成Linux平台下的包过滤防火墙,与大多数的Linux软件一样,这个包过滤防火墙是免费的,它可以代替昂贵的商业防火墙解决方案,完成封包过滤、封包重定向和网络地址转换(NAT)等功能。

3 iptables基础

规则(rules)其实就是网络管理员预定义的条件,规则一般的定义为“如果数据包头符合这样的条件,就这样处理这个数据包”。规则存储在内核空间的信息 包过滤表中,这些规则分别指定了源地址、目的地址、传输协议(如TCP、UDP、ICMP)和服务类型(如HTTP、FTP和SMTP)等。当数据包与规 则匹配时,iptables就根据规则所定义的方法来处理这些数据包,如放行(accept)、拒绝(reject)和丢弃(drop)等。配置防火墙的 主要工作就是添加、修改和删除这些规则。

4 iptabls传输数据过程

① 当一个数据包进入网卡时,它首先进入PREROUTING链,内核根据数据包目的IP判断是否需要转送出去。 
② 如果数据包就是进入本机的,它就会沿着图向下移动,到达INPUT链。数据包到了INPUT链后,任何进程都会收到它。本机上运行的程序可以发送数据包,这些数据包会经过OUTPUT链,然后到达POSTROUTING链输出。 
③ 如果数据包是要转发出去的,且内核允许转发,数据包就会如图所示向右移动,经过FORWARD链,然后到达POSTROUTING链输出。

5 iptabls的规则表和链

规则表(table)提供特定的功能,iptables内置了4个表

  • filter : 实现包过滤
  • nat表:网络地址转换
  • mangle: 包重构
  • raw表:数据跟踪处理

链(chains)是数据包传播的路径,每一条链其实就是众多规则中的一个检查清单,每一条链中可以有一条或数条规则。当一个数据包到达一个链时,iptables就会从链中第一条规则开始检查,看该数据包是否满足规则所定义的条件。如果满足,系统就会根据 该条规则所定义的方法处理该数据包;否则iptables将继续检查下一条规则,如果该数据包不符合链中任一条规则,iptables就会根据该链预先定义的默认策略来处理数据包。
       Iptables采用“表”和“链”的分层结构。在REHL4中是三表五链。现在REHL5成了四表五链了,不过多出来的那个表用的也不太多,所以基本还是和以前一样。下面罗列一下这四张表和五个链。注意一定要明白这些表和链的关系及作用。

INPUT:进来的数据包应用此规则链中的策略
OUTPUT:外出的数据包应用此规则链中的策略
FORWARD:转发数据包时应用此规则链中的策略
PREROUTING:对数据包作路由选择前应用此链中的规则
POSTROUTING:对数据包作路由选择后应用此链中的规则
6 iptables的命令

iptables [-t TABLE] 命令 链 [num] 匹配条件 -j 处理动作

TABLE :
     filter 过滤表
     nat 路由表
     mangle 包修改表
     raw 数据追踪表
命令:
管理规则
-A:附加一条规则,添加在链的尾部
-I CHAIN [num]: 插入一条规则,插入为对应CHAIN上的第num条;
-D CHAIN [num]: 删除指定链中的第num条规则;
-R CHAIN [num]: 替换指定的规则;
管理链:
-F [CHAIN]:flush,清空指定规则链,如果省略CHAIN,则可以实现删除对应表中的所有链
-P CHAIN: 设定指定链的默认策略;
-N:自定义一个新的空链
-X: 删除一个自定义的空链
-Z:置零指定链中所有规则的计数器;
-E: 重命名自定义的链;
查看类:
-L: 显示指定表中的规则;
-n: 以数字格式显示主机地址和端口号;
-v: 显示链及规则的详细信息
-vv:
-x: 显示计数器的精确值
--line-numbers: 显示规则号码
链(chain)
     PREROUTING : 数据在做路由决策前经过的链
     INPUT : 数据进入指定网卡的链
     FORWARD  : 数据转发链
OUTPUT : 数据流出指定网卡的链
POSTROUTING:数据最终要发出去的链
处理动作(target):
ACCEPT:放行
DROP:丢弃
REJECT:拒绝
DNAT:目标地址转换
SNAT:源地址转换
REDIRECT:端口重定向
MASQUERADE:地址伪装
LOG:日志
MARK:打标记
匹配标准:
通用匹配
-s 指定源ip
-d 指定目标ip
-p 指定协议,tcp,udp,icmp
-i 指定进入网卡名称
-o 指定流出网卡名称
扩展匹配
隐含扩展
-p tcp
--dport 目标端口
--sport 源端口
--tcp-flags mask comp 指定tcp标记, 掩码和值
--tcp-flags SYN,ACK,RST,FIN SYN
--syn
-p udp
--sport 源端口
--dport 目标端口
-p imcp
--icmp-type
: echo-request ping请求
: echo-reply ping应答
显式扩展
-m EXTENDSION_NAME --specific-opt -m state --state 状态,可以连接追踪tcp,utp,icmp。需要启用ip_conntrack, 一共四个值, 多个一起使用逗号分隔即可。
NEW, ESTABLISHED, RELATED, INVALID
-m multiport : 使用离散端口
--source-ports 源端口 , 多个端口逗号分隔
--destination-ports 目标端口, 多个端口逗号分隔
--ports 即使目标端口又是源端口,多个端口逗号分隔 -m iprange : ip范围匹配
--src-range 源ip范围 可以使用 172.16.0.0/16, 172.16.100.3-172.16.100.100
--dst-range 目标ip范围
iptables -A INPUT -p tcp -m iprange --src-range 172.16.100.3-172.16.100.100 --dport -m state --state NEW,ESTABLISHED -j ACCEPT -m connlimit: 连接数限制
! --connlimit-above n 连接数超过n个
iptables -A INPUT -d 172.16.100.7 -p tcp --dport -m connlimit --connlimit-above -j ACCEPT -m limit
--limit RATE 速率限定
--limit-burst 连接数限定 -m string 字符过滤
--algo {bm|kmp} 字符串匹配算法指定
--string "STRING" 指定字符串

7 常用iptables规则示例讲解

1 运行管理员通过同网段登录ssh管理

[root@localhost ~]# iptables -t filter -A INPUT -s 192.168.168.0/ -d 192.168..50 -p tcp --dport  -j ACCEPT
[root@localhost ~]# iptables -t filter -A OUTPUT -d 192.168..0/ -s 192.168..50 -p tcp --sport -j ACCEPT
-t 指定使用过滤表
-A指定链表
-s指定源地址
-d指定目标地址
-p指定协议
--dport指定端口号
-j指定动作

2.设置防火墙默认规则为DROP

[root@localhost ~]# iptables -P INPUT DROP
[root@localhost ~]# iptables -P OUTPUT DROP
[root@localhost ~]# iptables -P FORWARD DROP

3 只能我PING别人, 不允许别人PING我

[root@localhost ~]# iptables -A INPUT -p icmp --icmp-type  -s / -j DROP
[root@localhost ~]# iptables -A INPUT -p icmp --icmp-type -s / -j ACCEPT
[root@localhost ~]# iptables -A OUTPUT -p icmp --icmp-type -s 192.168.168.150 -j DROP
[root@localhost ~]# iptables -A OUTPUT -p icmp --icmp-type -s 192.168.168.150 -j ACCEPT
icmp-type 8代表ping请求,0代表ping应答。
我们的要求是我们能ping别人,别人不能ping我们,所以我们有4个规则指定,
我们自己发出去的ping请求都要通过,也就是从OUTPUT链发出的ping请求(icmp-type=8)都要ACCEPT 对应第四条语句
我们接受到的ping应答都要接受, 也就是从INPUT流入的ping应答(icmp-type=0)都要ACCEPT 对应第二条语句
我们接受的PING请求都要拒绝,对应第一条语句
我们发出去的PING应答都要拒绝,对应第三条语句

4 允许防火墙本机对外开放多个端口以及被动模式FTP端口1250-1280

[root@localhost ~]# iptables -A INPUT -p tcp -m multiport --dport ,,,,: -j ACCEPT
multiport就是一个多端口的扩展,逗号分隔各个端口,连续端口使用

5 只对同网段内的192.168.168.20-192.168.1.40的主机转发的数据包

[root@localhost ~]# iptables -A FORWARD -m iprange --src-range 192.168.168.20-192.168.168.40 -j ACCEPT

6 拒绝访问防火墙的新数据包,但允许响应连接或与已有连接相关的数据包

[root@localhost ~]# iptables -A INPUT -p tcp -m state --state NEW -j DROP
[root@localhost ~]# iptables -A INPUT -p tcp -m state --state ESTABLISHED,RELATED -j ACCEPT
RELEDTED 表示相关联的, 对于ftp连接来说,控制连接和数据连接两个套接字就是关联的

iptables防火墙常用配置介绍的更多相关文章

  1. Iptables 防火墙常用配置

    转至:https://blog.csdn.net/lswzw/article/details/87971259 Iptables 防火墙常用配置 概念 命令行模式 查看 & 命令 -n:直接显 ...

  2. centOS7.2防火墙常用配置(转)

    centOS7.2防火墙常用配置   firewall-cmd --state #查看默认防火墙状态(关闭后显示not running,开启后显示running) systemctl stop fir ...

  3. LINUX服务器搭建和常用配置介绍

    服务器搭建 : 搭建私有CA服务器 : http://www.cnblogs.com/zhaojiedi1992/p/zhaojiedi_linux_011_ca.html搭建samba服务器 : h ...

  4. Ubuntu 防火墙常用配置操作(ufw)【适用于 Debian 及其衍生版---Linux Mint、Deepin 等】-转

    Ubuntu 防火墙常用配置操作(ufw)[适用于 Debian 及其衍生版---Linux Mint.Deepin 等] 点击访问

  5. Centos7 防火墙常用配置及说明

    一. Centos7和Centos6 防火墙的区别: 使用的工具不一样了.Centos6 使用的是iptables ,Centos7 使用的是filewall iptables 用于过滤数据包,属于网 ...

  6. iptables防火墙常用命令

    iptables防火墙启动停止和基本操作 iptables是centos7之前常用的防火墙,在centos7上使用了firewall 防火墙基本操作: # 查询防火墙状态 service iptabl ...

  7. 第十章 nginx常用配置介绍

    一.虚拟主机 1.配置方式 #虚拟主机配置方式:1.基于多IP的方式2.基于多端口的方式3.基于多域名的方式 2.方式一:基于多IP的方式 1.第一个配置文件[root@web02 /etc/ngin ...

  8. hystrix -hystrix常用配置介绍

    配置官网介绍地址:https://github.com/Netflix/Hystrix/wiki/Configuration hystrix.command.default.execution.iso ...

  9. redis配置文件常用配置介绍

    博客内容首发地址 参数说明 redis.conf 配置项说明如下: Redis默认不是以守护进程的方式运行,可以通过该配置项修改,使用yes启用守护进程 daemonize no 当Redis以守护进 ...

随机推荐

  1. python Strip函数和Split函数的用法总结 (python2.0,但用法与3.0是差不多的)

    strip函数原型 声明:s为字符串,rm为要删除的字符序列. 只能删除开头或是结尾的字符或是字符串.不能删除中间的字符或是字符串. s.strip(rm)        删除s字符串中开头.结尾处, ...

  2. 渗透测试的理论部分4——开放式Web应用程序安全项目

    开放式Web应用程序安全项目(Open Web Application Security Project OWASP) 定期退出Top 10 project(排名前十的安全隐患防守规则) 公开了编写安 ...

  3. JPA-学习02

    一.主键生成策略 主键:确定一张表的唯一性东西(非空且唯一) 分为:自然主键和代理主键. 生成策略: identity:自增策略(1.值必须是数字,2.数据库支持) sequence:序列策略(同上, ...

  4. 20155205 郝博雅 Exp7 网络欺诈防范

    20155205 郝博雅 Exp7 网络欺诈防范 一.实践内容 (1)简单应用SET工具建立冒名网站 (1分) (2)ettercap DNS spoof (1分) (3)结合应用两种技术,用DNS ...

  5. 理解特性attribute 和 属性property的区别 及相关DOM操作总结

    查一下英语单词解释,两个都可以表示属性.但attribute倾向于解释为特质,而property倾向于解释私有的.这个property的私有解释可以更方便我们下面的理解. 第一部分:区别点 第一点:  ...

  6. Windows7+IIS+PHP7+MySQL5.7环境搭建

    IIS配置 本次搭建使用的系统是Windows7,Windows8,10与此类似. 开启IIS 开始-->控制面板-->程序和功能,点击左边栏的开启或关闭Windows功能,如图: 选择I ...

  7. BAT:文件中替换字符(保留空格和换行)

    @echo off rem CMD:"color --help" :: setting color:back white,content blue color f9 ::old s ...

  8. influence maximization

    Robust Influence Maximization 首先简要介绍一下这个问题:在一个社交网络图中寻找固定数量的节点,使得这些节点对所有节点的影响值尽可能的大.这个问题由于在病毒式营销,谣言监控 ...

  9. JQuery 操作数组 each、map、grep、filter

    Jquery中对数组的操作大致有一下几种形式:1.$.each( collection, callback(indexInArray, valueOfElement) )$.each()函数和$(se ...

  10. 河北大学python选修课00次作业

    学习python认为挺好玩的一件事.看到很多关于python的东西在网上,看到有这个课,认为只是选修课,别人也可以选,自己想不能被别人落下,别人都会,我不会可不行. 而且认为python是一个很强大的 ...