20个Linux防火墙[iptables]应用技巧[转]
1.显示防火墙的状态
以root权限运行下面的命令:
- # iptables -L -n -v
参数说明:
- -L:列出规则。
- -v:显示详细信息。此选项会显示接口名称、规则选项和TOS掩码,以及封包和字节计数。
- -n:以数字形式显示IP地址和端口,不使用DNS解析。
如果希望输出的结果中显示行号,可以运行:
- # iptables -L -n -v --line-nmubers
这样,就可以按照行号在防火墙中添加、删除规则。
要显示输入或输出链规则,可以运行:
- # iptables -L INPUT -n -v
- # iptables -L OUTPUT -n -v --line-numbers
2.停止、开启和重启防火墙
如果你使用的是RHEL/Fedora/CentOS系统,可以运行:
- # service iptables stop
- # service iptables start
- # service iptables restart
我们也可以使用iptables命令停止防火墙并删除所有规则:
- # iptables -F
- # iptables -X
- # iptables -t nat -F
- # iptables -t nat -X
- # iptables -t mangle -F
- # iptables -t mangle -X
- # iptables -P INPUT ACCEPT
- # iptables -P OUTPUT ACCEPT
- # iptables -P FORWARD ACCEPT
参数说明:
- -F:删除所有的规则
- -X:删除链
- -t table_name:匹配表(称为nat或mangle)
- -P:设置默认策略(如DROP、REJECT或ACCEPT)
3.删除防火墙规则
以带行号的形式显示已有的防火墙规则,请运行:
- # iptables -L INPUT -n --line-numbers
- # iptables -L OUTPUT -n --line-numbers
- # iptables -L OUTPUT -n --line-numbers | less
- # iptables -L OUTPUT -n --line-numbers | grep 202.54.1.1
下面我们使用行号删除规则:
- # iptables -D INPUT 4
将IP地址202.54.1.1从规则中删除:
- # iptables -D INPUT -s 202.54.1.1 -j DROP
参数说明:
- -D:从选择的链中删除一条或多条规则
4.插入防火墙规则
首先运行下面的命令:
- # iptables -L INPUT -n --line-numbers
得到运行结果:
- Chain INPUT (policy DROP)
- num target prot opt source destination
- 1 DROP all -- 202.54.1.1 0.0.0.0/0
- 2 ACCEPT all -- 0.0.0.0/0 0.0.0.0/0
在行1和行2之间插入规则:
- # iptables -I INPUT 2 -s 202.54.1.2 -j DROP
查看更新后的规则,会发现插入成功,下面是示例:
- Chain INPUT (policy DROP)
- Num target prot opt source destination
- 1 DROP all -- 202.54.1.1 0.0.0.0/0
- 2 DROP all -- 202.54.1.2 0.0.0.0/0
- 3 ACCEPT all -- 0.0.0.0/0 0.0.0.0/0
5.保存防火墙规则
在RHEL/Fedora/CentOS Linux下,可以使用下面的命令保存防火墙规则:
- # service iptables save
在其它Linux发行版(如Ubuntu)上,可以使用iptables-save命令保存防火墙规则:
- # iptables-save > /root/my.active.firewall.rules
- # cat /root/my.active.firewall.rules
6.重新加载防火墙规则
我们可以使用iptables-restore命令重新加载使用iptables-save命令保存的防火墙规则:
- # iptables-restore < /root/my.active.firewall.rules
我们还可以利用这种特性来快速部署防火墙规则。
7.设置默认防火墙策略
我们首先来配置一个防火墙策略,它默认丢弃所有的网络数据包:
- # iptables -P INPUT DROP
- # iptables -P OUTPUT DROP
- # iptables -P FORWARD DROP
- # iptables -L -v -n
- #连接失败,因为防火墙丢弃所有的网络数据包
- # ping cyberciti.biz
- # wget http://www.kernel.org/pub/linux/kernel/v3.0/testing/linux-3.2-rc5.tar.bz2
在此基础上,我们只关闭入站连接:
- # iptables -P INPUT DROP
- # iptables -P FORWARD DROP
- # iptables -P OUTPUT ACCEPT
- # iptables -A INPUT -m state --state NEW,ESTABLISHED -j ACCEPT
- # iptables -L -v -n
- #ping和wget可以正常工作
- # ping cyberciti.biz
- # wget http://www.kernel.org/pub/linux/kernel/v3.0/testing/linux-3.2-rc5.tar.bz2
8.在公网网络接口上停用私有网络地址
我们可以从公网网络接口上删除私有IPv4网段,以防止IP欺骗。运行下面的命令,没有源路由地址的数据包会被丢弃:
- # iptables -A INPUT -i eth1 -s 192.168.0.0/24 -j DROP
- # iptables -A INPUT -i eth1 -s 10.0.0.0/8 -j DROP
下面是私有网络IPv4地址范围,请确认在公网接口予以屏蔽:
- 10.0.0.0/8 -j (A)
- 172.16.0.0/12 (B)
- 192.168.0.0/16 (C)
- 224.0.0.0/4 (多播 D)
- 240.0.0.0/5 (E)
- 127.0.0.0/8 (回环)
9.屏蔽IP地址访问
如果我们想屏蔽一个IP地址,比如1.2.3.4,可以运行:
- # iptables -A INPUT -s 1.2.3.4 -j DROP
- # iptables -A INPUT -s 192.168.0.0/24 -j DROP
10.屏蔽入栈端口请求
如果我们想80端口上屏蔽所有的服务请求,可以运行:
- # iptables -A INPUT -p tcp --dport 80 -j DROP
- # iptables -A INPUT -i eth1 -p tcp --dport 80 -j DROP
只想屏蔽IP地址1.2.3.4对80端口的请求,可以运行:
- # iptables -A INPUT -p tcp -s 1.2.3.4 --dport 80 -j DROP
- # iptables -A INPUT -i eth1 -p tcp -s 192.168.1.0/24 --dport 80 -j DROP
11.屏蔽出栈IP地址
现在我们来演示如何屏蔽对主机名和IP地址的出栈访问。
首先,我们来获取一个域名的IP地址:
- # host -t a cyberciti.biz
输出示例:
- cyberciti.biz has address 75.126.153.206
要屏蔽访问域名cyberciti.biz的网络数据包,可以运行:
- # iptables -A OUTPUT -d 75.126.153.206 -j DROP
下面是使用子网掩码的示例:
- # iptables -A OUTPUT -d 192.168.1.0/24 -j DROP
- # iptables -A OUTPUT -o eth1 -d 192.168.1.0/24 -j DROP
下面我们以屏蔽facebook.com为例,进行说明。首先,我们需要facebook的所有IP地址:
- # host -t a www.facebook.com
示例输出:
- www.facebook.com has address 69.171.228.40
找出IP地址69.171.228.40的CIDR:
- # whois 69.171.228.40 | grep CIDR
示例输出:
- CIDR:69.171.224.0/19
现在我们来阻止对facebook.com的访问:
- # iptables -A OUTPUT -p tcp -d 69.171.224.0/19 -j DROP
我们也可以直接屏蔽域名:
- # iptables -A OUTPUT -p tcp -d www.facebook.com -j DROP
- # iptables -A OUTPUT -p tcp -d facebook.com -j DROP
12.记录并丢弃数据包
在公网网络接口上记录并丢弃IP地址欺骗数据包:
- # iptables -A INPUT -i eth1 -s 10.0.0.0/8 -j LOG --log-prefix "IP_SPOOF A: "
- # iptables -A INPUT -i eth1 -s 10.0.0.0/8 -j DROP
默认情况下日志记录在/var/log/messages文件中:
- # tail -f /var/log/messages
- # grep --color 'IP SPOOF' /var/log/messages
我们还可以用-m参数对日志记录进行限制,以防止日志文件过度膨胀。
- # iptables -A INPUT -i eth1 -s 10.0.0.0/8 -m limit --limit 5/m --limit-burst 7 -j LOG --log-prefix "IP_SPOOF A: "
- # iptables -A INPUT -i eth1 -s 10.0.0.0/8 -j DROP
13.根据MAC地址允许或阻止数据包的传入
我们可以根据MAC地址允许或阻止数据包的传入:
- # iptables -A INPUT -m mac --mac-source 00:0F:EA:91:04:08 -j DROP
14.屏蔽ICMP ping请求
我们可以通过允许下面的命令屏蔽ping请求:
- # iptables -A INPUT -p icmp --icmp-type echo-request -j DROP
- # iptables -A INPUT -i eth1 -p icmp --icmp-type echo-request -j DROP
也可以按照特定的网段和主机限制ping请求:
- # iptables -A INPUT -s 192.168.1.0/24 -p icmp --icmp-type echo-request -j ACCEPT
以下命令只接受受限制的ping请求:
- #假定默认INPUT策略为丢弃数据包
- # iptables -A INPUT -p icmp --icmp-type echo-reply -j ACCEPT
- # iptables -A INPUT -p icmp --icmp-type destination-unreachable -j ACCEPT
- # iptables -A INPUT -p icmp --icmp-type time-exceeded -j ACCEPT
- #所有的服务器都对ping请求作出应答
- # iptables -A INPUT -p icmp --icmp-type echo-request -j ACCEPT
15.开启端口序列
下面的命令可以允许7000到7010范围内的TCP端口访问:
- # iptables -A INPUT -m state --state NEW -m tcp -p tcp --dport 7000:7010 -j ACCEPT
16.允许一系列IP地址访问
下面的命令可以允许IP地址范围
- #运行IP地址范围192.168.1.100 到192.168.1.200 访问80端口
- # iptables -A INPUT -p tcp --destination-port 80 -m iprange --src-range 192.168.1.100-192.168.1.200 -j ACCEPT
- #NAT示例
- # iptables -t nat -A POSTROUTING -j SNAT --to-source 192.168.1.20-192.168.1.25
17.建立连接并重启防火墙
当重启iptables服务时,它会断开所有已建立的连接。这是因为在重启防火墙时,会卸载IPTABLES_MODULES_UNLOAD模块。
要解决这个问题,可以编辑/etc/sysconfig/iptables-config
- IPTABLES_MODULES_UNLOAD = no
18.使用Crit日志级别
- # iptables -A INPUT -s 1.2.3.4 -p tcp --destination-port 80 -j LOG --log-level crit
19.屏蔽或开启常见端口
屏蔽或开启常用的TCP、UDP端口:
- #可以使用DROP替换ACCEPT,实现端口屏蔽。
- #打开22端口(SSH)
- # iptables -A INPUT -m state --state NEW -m tcp -p tcp --dport 22 -j ACCEPT
- # iptables -A INPUT -s 192.168.1.0/24 -m state --state NEW -p tcp --dport 22 -j ACCEPT
- #打开TCP/UDP631端口(打印服务)
- # iptables -A INPUT -s 192.168.1.0/24 -p udp -m udp --dport 631 -j ACCEPT
- # iptables -A INPUT -s 192.168.1.0/24 -p tcp -m tcp --dport 631 -j ACCEPT
- # 打开123端口,允许局域网用户进行NTP时间同步
- # iptables -A INPUT -s 192.168.1.0/24 -m state --state NEW -p udp --dport 123 -j ACCEPT
- #打开25端口(SMTP)
- # iptables -A INPUT -m state --state NEW -p tcp --dport 25 -j ACCEPT
- # 打开DNS端口
- # iptables -A INPUT -m state --state NEW -p udp --dport 53 -j ACCEPT
- # iptables -A INPUT -m state --state NEW -p tcp --dport 53 -j ACCEPT
- #打开http/https端口
- # iptables -A INPUT -m state --state NEW -p tcp --dport 80 -j ACCEPT
- # iptables -A INPUT -m state --state NEW -p tcp --dport 443 -j ACCEPT
- #打开TCP110端口(POP3)
- # iptables -A INPUT -m state --state NEW -p tcp --dport 110 -j ACCEPT
- #打开TCP143端口
- # iptables -A INPUT -m state --state NEW -p tcp --dport 143 -j ACCEPT
- #为局域网用户开启Samba访问
- # iptables -A INPUT -s 192.168.1.0/24 -m state --state NEW -p tcp --dport 137 -j ACCEPT
- # iptables -A INPUT -s 192.168.1.0/24 -m state --state NEW -p tcp --dport 138 -j ACCEPT
- # iptables -A INPUT -s 192.168.1.0/24 -m state --state NEW -p tcp --dport 139 -j ACCEPT
- # iptables -A INPUT -s 192.168.1.0/24 -m state --state NEW -p tcp --dport 445 -j ACCEPT
- #为局域网用户开启代理服务器访问
- # iptables -A INPUT -s 192.168.1.0/24 -m state --state NEW -p tcp --dport 3128 -j ACCEPT
- #为局域网用户开启MySQL访问
- # iptables -I INPUT -p tcp --dport 3306 -j ACCEPT
20.限制客户端IP的并发连接数
我们可以使用connlimit模块限制客户端IP的并发连接数。下面的命令允许每个客户端只能并发3个ssh连接:
- # iptables -A INPUT -p tcp --syn --dport 22 -m connlimit --connlimit-above 3 -j REJECT
设置HTTP并发连接为20个:
- # iptables -p tcp --syn --dport 80 -m connlimit --connlimit-above 20 --connlimit-mask 24 -j DROP
参数说明:
- --connlimit-above 3:连接数超过3个自动匹配
- --connlimit-mask 24:子网掩码匹配
更好的使用iptables
首先,我们要学会查看man手册:
- $ man iptables
我们还可以这样查看帮助:
- # iptables -h
我们还可以查看特定命令的帮助:
- # iptables -j DROP -h
测试防火墙
测试端口是否开放:
- # netstat -tulpn
测试TCP 80端口是否开放:
- # netstat -tulpn | grep :80
如果80端口未开放,请确保启动Apache服务器:
- # service httpd start
并确保打开iptables防火墙80端口:
- # iptables -L INPUT -v -n | grep 80
如果80端口没有开放,可以运行下面的命令:
- # iptables -A INPUT -m state --state NEW -p tcp --dport 80 -j ACCEPT
- # service iptables save
下面使用telnet命令测试是否可以连接到80端口:
- $ telnet www.cyberciti.biz 80
下面是示例输出:
- Trying 75.126.153.206...
- Connected to www.cyberciti.biz.
- Escape character is '^]'.
- ^]
- telnet> quit
- Connection closed.
最后,我们也推荐使用嗅探工具(如tcpdump、ngrep)对防火墙设置进行测试。
以上只是一些基本的防火墙配置策略,如果你想构造更复杂的防火墙策略,需要对TCP/IP和Linux内核配置文件sysctl.conf进行更深入的学习。
20个Linux防火墙[iptables]应用技巧[转]的更多相关文章
- linux 防火墙iptables简明教程
前几天微魔部落再次遭受到个别别有用心的攻击者的攻击,顺便给自己充个电,复习了一下linux下常见的防火墙iptables的一些内容,但是无奈网上的很多教程都较为繁琐,本着简明化学习的目的,微魔为大家剔 ...
- Linux防火墙iptables简明教程
前几天微魔部落再次遭受到个别别有用心的攻击者的攻击,顺便给自己充个电,复习了一下linux下常见的防火墙iptables的一些内容,但是无奈网上的很多教程都较为繁琐,本着简明化学习的目的,微魔为大家剔 ...
- Linux防火墙iptables学习笔记(三)iptables命令详解和举例[转载]
Linux防火墙iptables学习笔记(三)iptables命令详解和举例 2008-10-16 23:45:46 转载 网上看到这个配置讲解得还比较易懂,就转过来了,大家一起看下,希望对您工作能 ...
- Linux防火墙iptables学习
http://blog.chinaunix.net/uid-9950859-id-98277.html 要在网上传输的数据会被分成许多小的数据包,我们一旦接通了网络,会有很多数据包进入,离开,或者经过 ...
- Linux防火墙(Iptables)的开启与关闭
Linux防火墙(iptables)的开启与关闭 Linux中的防火墙主要是对iptables的设置和管理. 1. Linux防火墙(Iptables)重启系统生效 开启: chkconfig ipt ...
- 10.Linux防火墙iptables之SNAT与DNAT
Linux防火墙iptables之SNAT与DNAT 目录 Linux防火墙iptables之SNAT与DNAT SNAT策略及应用 SNAT策略概述 SNAT策略典型应用环境 SNAT策略原理 SN ...
- linux 防火墙 iptables实例讲解
端口为例): 显示现有规则: iptables –L -n 清空现有规则表: iptables -F 黑名单:先允许所有数据包通过,后逐条添加黑名单规则. iptables –A INPUT–p tc ...
- Linux防火墙iptables介绍
介绍网络防火墙是通过一个或多个允许或拒绝的规则来过滤网络流量的网络设备或软件.网络防火墙还可以执行更复杂的任务,例如网络地址转换,带宽调整,提供加密隧道以及更多与网络流量相关的任务.而我们的任务就是需 ...
- linux 防火墙 iptables 目录
linux iptables 防火墙简介 Linux 防火墙:Netfilter iptables 自动化部署iptables防火墙脚本
随机推荐
- 【docker】【Gitlab】gitlab中clone项目时,IP地址是一串数字(内网Gitlab的IP地址不正确)的问题解决
首次在内网搭建Gitlab环境,在成功后在Gitlab上新建了一个项目. 然而在IDEA上clone项目时发现,项目地址如下: git@0096ce63c43f:root/jump.git 或者这样 ...
- 用UIBezierPath数组对UIView进行镂空处理
用UIBezierPath数组对UIView进行镂空处理 效果 源码 // // CutOutClearView.h // CutOutMaskView // // Created by YouXia ...
- Android之针对WebView的全屏播放
转载请标明转载处:http://bbs.csdn.net/topics/390839259 本人刚学android,菜鸟一个,第一次写帖子,最近因为项目要用webview加载html5的视频,开始不能 ...
- Kubernetes基础
Kubernetes是什么 Kubernetes是当今最流行的开源容器管理平台,它就是大名鼎鼎的Google Borg的开源版本.Google在2014年推出了Kubernetes,本文发布时最新的版 ...
- 深入理解多线程(五)—— Java虚拟机的锁优化技术
本文是<深入理解多线程>的第五篇文章,前面几篇文章中我们从synchronized的实现原理开始,一直介绍到了Monitor的实现原理. 前情提要 通过前面几篇文章,我们已经知道: 1.同 ...
- LRU和LFU的区别
版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/guoweimelon/article/details/50855351 一.概念介绍 LRU和LFU ...
- git如何删除远端不存在的本地分支?
问题:远端分支删除后,如何删除之前拉取的本地分支? 答案: git fetch -p git remote show origin 可以查看remote地址,远程分支,还有本地分支与之相对应关系等信息 ...
- SQL Server 函数 LEN 与 DATALENGTH的区别
http://blog.csdn.net/Hello_World_wusu/article/details/4667452 DATALENGTH()函数返回一个用于对值进行管理的字节数,这有助于揭示不 ...
- warning: LF will be replaced by CRLF in dubbo-demo-api/pom.xml.
今天使用git add .的时候出现了一个错误. 错误如下: 解决方案: $ rm -rf .git // 删除.git $ git config --global core.autocrlf fal ...
- Windows server 2008 r2 如何开启Win7的Aero效果 (转)
Aero 桌面体验为开放式外观提供了类似于玻璃的窗口. 它包括与众不同的直观样式,将轻型透明的窗口外观与强大的图形高级功能结合在一起.您可以享受具有视觉冲击力的效果和外观,并可从更快地访问程序中获益. ...