1. iptables 命令基本语法
“iptables [-t table] command [链名] [条件匹配] [-j 目标动作]
以下是对 iptables 命令的拆分讲解:
1.2 -t table
用来指明使用的表,有三种选项: filter
,nat
,mangle
。若未指定,则默认使用filter表。
1.3 command参数
指定iptables 对我们提交的规则要做什么样的操作,以下是command常用参数:
-A
Append,追加一条规则(放到最后)
1 | 举例:iptables -A INPUT -j DROP #拒绝所有人访问服务器(作为最后一条规则) |
-I
Insert,在指定的位置插入规则
1 | 举例:iptables -I INPUT 2 -s 10.10.10.1 -j ACCEPT #允许10.10.10.1主机访问本机 |
-L
List,查看规则列表
1 | 具体参数:n:只显示 IP 地址和端口号码,不显示域名和服务名称 |
1 | 举例:iptables -nL --line-number |
-D
Delete,从规则列表中删除规则
1 | 举例:iptables -D INPUT 2 |
-P
Policy,设置某个链的默认规则
1 | 举例:iptables -P INPUT DROP |
“当数据包没有被任何规则匹配时,则按默认规则处理。
-F
Flush,清空规则
1 | 举例: |
“注意:-F 是清空链中规则,但并不影响 -P 设置的默认规则。因此在生产环境中,若指定默认规则为DROP,一旦执行
iptables -F
,很容易导致自己也无法连接服务器(-F 会把配置的明细ACCEPT规则删除,只留下默认规则拒接所有)。
-Z
zero,将指定链的所有计数器归零。(如未指定,则认为是所有链)
1 | 举例: |
1.4 条件匹配参数
1.4.1 按网络接口匹配
-i
匹配数据进入的网络接口,此参数主要应用nat表,例如目标地址转换。
-o
匹配数据流出的网络接口
1 | 举例: |
1.4.2 按源及目的地址匹配
-s
匹配源地址,可以是IP、网段、域名,也可空(代表任何地址)
-d
匹配目标地址
1 | 举例: |
1.4.3 按协议类型匹配
-p
匹配协议类型,可以是TCP、UDP、ICMP等
1 | 举例: |
1.4.4 按源及目的端口匹配
--sport
匹配源端口;可以是单个端口,也可以是端口范围
--dport
匹配目的端口
1 | 举例: |
“注意:–sport 和 –dport 必须配合 -p 参数使用,例如:
1 | iptables -A INPUT -p tcp –dport 80 -j ACCEPT |
1.5 目的动作
-j ACCEPT
允许数据包通过本链而不拦截它
1 | 举例: |
-j DROP
丢弃数据包;阻止数据包通过本链
1 | 举例: |
-j SNAT
源地址转换,支持转换为单IP,也支持转换到IP地址池
1 | 举例: |
-j DNAT
目的地址转换,支持转换为单IP,也支持转换到IP地址池
1 | 举例: |
-j MASQUERADE
动态SNAT转换(适用于动态 IP 场景 )
1 | 举例: |
2.iptables 常用附加模块
2.1 按包状态匹配 (state)
1 | -m state --state 状态 |
2.2按来源 MAC 匹配(mac)
1 | -m mac --mac-source MAC |
2.3 按包速率匹配 (limit)
1 | -m limit --limit 匹配速率 |
“limit 英语上看是限制的意思,但实际上只是按一定速率去匹配而已,50/s 表示 1 秒中转发 50 个数据包,要想限制的话后面要再跟一条DROP规则
2.4 多端口匹配 (multiport)
1 | -m multiport <--sports|--dports|--ports> 端口 1[,端口 2,..,端口 n] |
“注意:该参数必须与 -p 参数一起使用
3. iptables 规则备份和恢复
“我们执行 iptables 命令时,规则只是保存在内存中,并没有保存到某一个文件中。因此系统重启之后,之前设定的规则就没有了,所以规则设定完毕,检查无误后要及时保存规则,使用命令:
1 | [root@LB-01 ~]# service iptables save |
会看到提示,防火墙规则保存在/etc/sysconfig/iptables
文件内,这个文件就是iptables的配置文件。所以如果要备份防火墙规则,复制该配置文件即可。例如:
1 | cp /etc/sysconfig/iptables /opt/myipt.rule |
如果需要恢复这些规则,使用以下命令:
1 | iptables-restore < /opt/myipt.rule |
- 本文作者: Veng
- 本文链接: http://veng0923.github.io/2022/08/19/iptables/
- 版权声明: 本博客所有文章除特别声明外,均采用 MIT 许可协议。转载请注明出处!