2-iptables

本贴最后更新于 1396 天前,其中的信息可能已经渤澥桑田

3 iptables

3.1 iptables 规则说明

3.1.1 iptables 规则组成

规则 rule:根据规则的匹配条件尝试匹配报文,对匹配成功的报文根据规则定义的处理动作作出处理,规则在链接上的次序即为其检查时的生效次序

匹配条件:默认为与条件,同时满足

基本匹配:IP,端口,TCP 的 Flags(SYN,ACK 等)

扩展匹配:通过复杂高级功能匹配

处理动作:称为 target,跳转目标

  • 内建处理动作 ACCEPT(允许),DROP(抛弃),REJECT(拒绝),SNAT,DNAT,MASQUERADE,MARK,LOG...
  • 自定义处理动作:自定义 chain,利用分类管理复杂情形

规则要添加在链上,才生效;添加在自定义链上不会自动生效

白名单:只有指定的特定主机可以访问,其它全拒绝

黑名单:只有指定的特定主机拒绝访问,其它全允许,默认方式

3.1.2 iptables 规则添加时考量点

  • 要实现哪种功能:判断添加在哪张表上
  • 报文流经的路径:判断添加在哪个链上
  • 报文的流向:判断源和目的
  • 匹配规则:业务需要

3.1.3 环境准备

Centos7,8:
systemctl disable --now firewalld

Centos6:
service stop iptables
chkconfig iptables off

3.2 iptables 用法说明

帮助:man 8 iptables

格式:

iptables [-t table] {-A|-C|-D} chain rule-specification
iptables [-t table] -I chain [rulenum] rule-specification
iptables [-t table] -R chain rulenum rule-specification
iptables [-t table] -D chain rulenum
iptables [-t table] -S [chain [rulenum]]
iptables [-t table] {-F|-L|-Z} [chain [rulenum]] [options...]
iptables [-t table] -N chain
iptables [-t table] -X [chain]
iptables [-t table] -P chain target
iptables [-t table] -E old-chain-name new-chain-name
rule-specification = [matches...] [target]
match = -m matchname [per-match-options]
target = -j targetname [per-target-options]

范例:Filter 表中 INPUT 规则

clipboard.png

iptables 命令格式详解:

iptables   [-t table]   SUBCOMMAND   chain   [-m matchname [per-match-options]]
-j targetname [per-target-options]
  1. -t table:指定表
  • raw, mangle, nat, [filter]默认
  1. SUBCOMMAND:子命令

3.2.1 链管理类:

-N:new, 自定义一条新的规则链
-E:重命名自定义链;引用计数不为0的自定义链不能够被重命名,也不能被删除
-X:delete,删除自定义的空的规则链
-P:Policy,设置默认策略;对filter表中的链而言,其默认策略有:ACCEPT:接受, DROP:丢弃

范例:自定义链的使用,正常很少使用

[14:32:04 root@centos8 ~]#iptables -N web_chain           #创建链,不写表名称默认filter表
[14:35:43 root@centos8 ~]#iptables -N web_chain -t nat    #把链关联到表
[14:36:55 root@centos8 ~]#iptables -E web_chain WEB_CHAIN #修改链名称
[14:38:02 root@centos8 ~]#iptables -A WEB_CHAIN -s 192.168.10.71 -p tcp -m multiport --dports 80,443,8080 -j REJECT
[14:43:15 root@centos8 ~]#iptables -vnL WEB_CHAIN
[14:43:48 root@centos8 ~]#iptables -AINPUT -j WEB_CHAIN
[14:44:38 root@centos8 ~]#iptables -X WEB_CHAIN
[14:46:24 root@centos8 ~]#iptables -F WEB_CHAIN
[14:47:14 root@centos8 ~]#iptables -X WEB_CHAIN
[14:47:53 root@centos8 ~]#iptables -D INPUT 1
[14:48:17 root@centos8 ~]#iptables -X WEB_CHAIN

3.2.2 查看类

-L:list, 列出指定鏈上的所有规则,本选项须置后
-n:numberic,以数字格式显示地址和端口号
-v:verbose,详细信息
-vv 更详细
-x:exactly,显示计数器结果的精确值,而非单位转换后的易读值
--line-numbers:显示规则的序号
-S selected,以iptables-save 命令格式显示链上规则

常用组合:

[17:49:50 root@centos7 ~]#iptables -nvL
[17:49:13 root@centos7 ~]#iptables -vnL --line-numbers

3.2.3 规则管理类

-A:append,追加
-I:insert, 插入,要指明插入至的规则编号,默认为第一条
-D:delete,删除
(1) 指明规则序号
(2) 指明规则本身
-R:replace,替换指定链上的指定规则编号
-F:flush,清空指定的规则链
-Z:zero,置零
iptables的每条规则都有两个计数器
(1) 匹配到的报文的个数
(2) 匹配到的所有报文的大小之和

范例:

[17:53:31 root@centos8 ~]#iptables -F OUTPUT
  1. chain(链)
PREROUTING,INPUT,FORWARD,OUTPUT,POSTROUTING
  1. 匹配条件
  • 基本:通用的,PARAMETERS
  • 扩展:需加载模块,MATCH EXTENTIONS
  1. 处理动作
-j targetname [per-target-options]

简单动作:

ACCEPT    拒绝,会给对方发送回应拒绝包
DROP      丢弃,不会给对方返回任何包

扩展动作:

REJECT:--reject-with:icmp-port-unreachable默认
RETURN:返回调用链
REDIRECT:端口重定向
LOG:记录日志,dmesg
MARK:做防火墙标记
DNAT:目标地址转换
SNAT:源地址转换
MASQUERADE:地址伪装
自定义链

3.3 iptables 基本匹配条件

基本匹配条件:无需加载模块,由 iptables/netfilter 自行提供

[!] -s, --source address[/mask][,...]:源IP地址或者不连续的IP地址
[!] -d, --destination address[/mask][,...]:目标IP地址或者不连续的IP地址
[!] -p, --protocol protocol:指定协议,可使用数字如0(all)
protocol: tcp, udp, icmp, icmpv6, udplite,esp, ah, sctp, mh or“all“
参看:/etc/protocols
[!] -i, --in-interface name:报文流入的接口;只能应用于数据报文流入环节,只应用于INPUT、FORWARD、PREROUTING链
[!] -o, --out-interface name:报文流出的接口;只能应用于数据报文流出的环节,只应用于FORWARD、OUTPUT、POSTROUTING链

范例:

[18:18:02 root@centos8 ~]#iptables -AINPUT -s 192.168.10.81 -j REJECT
[18:18:38 root@centos8 ~]#iptables -IINPUT -i lo -j ACCEPT
[18:20:27 root@centos8 ~]#curl 127.0.0.1
zhangzhuo.org
[18:20:50 root@centos8 ~]#curl 192.168.10.81
zhangzhuo.org

3.4 iptables 扩展匹配条件

扩展匹配条件:需要加载扩展模块(/usr/lib64/xtables/*.so),方可生效

扩展模块的查看帮助 :man iptables-extensions

扩展匹配条件:

  • 隐式扩展
  • 显式扩展

3.4.1 隐式扩展

iptables 在使用-p 选项指明了特定的协议时,无需再用-m 选项指明扩展模块的扩展机制,不需要手动加

载扩展模块

tcp 协议的扩展选项

[!] --source-port, --sport port[:port]:匹配报文源端口,可为端口连续范围
[!] --destination-port,--dport port[:port]:匹配报文目标端口,可为连续范围
[!] --tcp-flags mask comp
mask 需检查的标志位列表,用,分隔 , 例如 SYN,ACK,FIN,RST
comp 在mask列表中必须为1的标志位列表,无指定则必须为0,用,分隔tcp协议的扩展选项

范例:

--tcp-flags SYN,ACK,FIN,RST SYN 表示要检查的标志位为SYN,ACK,FIN,RST四个,其中SYN必
须为1,余下的必须为0,第一次握手
--tcp-flags SYN,ACK,FIN,RST SYN,ACK 第二次握手
#错误包
--tcp-flags ALL ALL
--tcp_flags ALL NONE

[!] --syn:用于匹配第一次握手, 相当于:--tcp-flags SYN,ACK,FIN,RST SYN

udp 协议的扩展选项

[!] --source-port, --sport port[:port]:匹配报文的源端口或端口范围
[!] --destination-port,--dport port[:port]:匹配报文的目标端口或端口范围

icmp 协议的扩展选项

[!] --icmp-type {type[/code]|typename}
type/code
0/0   echo-reply icmp应答
8/0   echo-request icmp请求

范例:禁止到本机访问 http 服务 80 端口

[18:35:42 root@centos8 ~]#iptables -A INPUT -d 192.168.10.81 -p tcp --dport 80 -j REJECT
[18:36:19 root@centos8 ~]#iptables -vnL --line-numbers
Chain INPUT (policy ACCEPT 0 packets, 0 bytes)
num   pkts bytes target     prot opt in     out     source               destination
1        1    60 REJECT     tcp  --  *      *       0.0.0.0/0            192.168.10.81        tcp dpt:80 reject-with icmp-port-unreachable

Chain FORWARD (policy ACCEPT 0 packets, 0 bytes)
num   pkts bytes target     prot opt in     out     source               destination

Chain OUTPUT (policy ACCEPT 0 packets, 0 bytes)
num   pkts bytes target     prot opt in     out     source               destination

范例:匹配第一次握手的请求拒绝

[18:39:23 root@centos8 ~]#iptables -AINPUT -p tcp --syn -j REJECT

范例:拒绝 ICMP 的请求包

[18:40:45 root@centos8 ~]#iptables -AINPUT -s 192.168.10.71 -p icmp --icmp-type 8 -j REJECT

3.4.2 显示扩展及相关模块

显示扩展即必须使用-m 选项指明要调用的扩展模块名称,需要手动加载扩展模块

[-m matchname [per-match-options]]

扩展模块的使用帮助:

  • CentOS 7,8: man iptables-extensions
  • CentOS 6: man iptables

3.4.2.1 multiport 扩展

以离散方式定义多端口匹配,最多指定 15 个端口

#指定多个源端口
[!] --source-ports,--sports port[,port|,port:port]...
# 指定多个目标端口
[!] --destination-ports,--dports port[,port|,port:port]...
#多个源或目标端
[!] --ports port[,port|,port:port]

范例:禁止多个端口访问

[18:44:47 root@centos8 ~]#iptables -A INPUT -s 192.168.10.0/24 -d 192.168.10.1 -p tcp -m multiport --dports 20:22,80 -j REJECT
[18:46:27 root@centos8 ~]#iptables -AINPUT -s 192.168.10.71 -p tcp -m multiport --dports 445,139 -j REJECT

3.4.2.2 iprange 扩展

指明连续的(但一般不是整个网络)ip 地址范围

[!] --src-range from[-to] 源IP地址范围
[!] --dst-range from[-to] 目标IP地址范围

范例:禁止 192.168.10.71-192.168.10.72 访问本机的 80 端口

[18:50:13 root@centos8 ~]#iptables -AINPUT -d 192.168.10.81 -p tcp --dport 80 -m iprange --src-range 192.168.10.71-192.168.10.75 -j DROP

3.4.2.3 mac 扩展

mac 模块可以指明源 MAC 地址,,适用于:PREROUTING, FORWARD,INPUT chains

[!] --mac-source XX:XX:XX:XX:XX:XX

范例:禁止地址为 192.168.10.71 且 mac 地址为 00:0c:29:c1:8a:39 访问本机

[18:52:25 root@centos8 ~]#iptables -AINPUT -s 192.168.10.71 -m mac --mac-source 00:0c:29:c1:8a:39 -j RE
JECT

3.4.2.4 string 扩展

对报文中的应用层数据做字符串模式匹配检测

--algo {bm|kmp} 字符串匹配检测算法
bm:Boyer-Moore
kmp:Knuth-Pratt-Morris
--from offset 开始偏移
--to offset   结束偏移
[!] --string pattern 要检测的字符串模式
[!] --hex-string pattern要检测字符串模式,16进制格式

范例:

[18:59:35 root@centos8 ~]#iptables -AOUTPUT -ptcp --sport 80 -m string --algo bm --from 62 --string "zhangzhuo" -j REJECT

3.4.2.5 time 扩展

注意:CentOS 8 此模块有问题

根据将报文到达的时间与指定的时间范围进行匹配

--datestart YYYY[-MM[-DD[Thh[:mm[:ss]]]]] 日期
--datestop YYYY[-MM[-DD[Thh[:mm[:ss]]]]]
--timestart hh:mm[:ss]       时间
--timestop hh:mm[:ss]
[!] --monthdays day[,day...]   每个月的几号
[!] --weekdays day[,day...]   星期几,1 – 7 分别表示星期一到星期日
--kerneltz:内核时区(当地时间),不建议使用,CentOS 7版本以上系统默认为 UTC
注意: centos6 不支持kerneltz ,--localtz指定本地时区(默认)

范例: CentOS 8 的 time 模块问题

[root@centos8 ~]#rpm -ql iptables |grep time
/usr/lib64/xtables/libxt_time.so
[root@centos8 ~]#iptables -A INPUT -m time --timestart 12:30 --timestop 13:30 -j
ACCEPT
iptables v1.8.4 (nf_tables): Couldn't load match `time':No such file or
directory

范例:

[19:06:48 root@centos7 ~]#iptables -IINPUT -s 192.168.10.0/24 -p icmp --icmp-type 8 -m time --timestart 11:00 --timestop 20:00 -j DROP

3.4.2.6 connlimit 扩展

根据每客户端 IP 做并发连接数数量匹配

可防止 Dos(Denial of Service,拒绝服务)攻击

--connlimit-upto N #连接的数量小于等于N时匹配
--connlimit-above N #连接的数量大于N时匹配

范例:

[13:43:54 root@centos8 ~]#iptables -A INPUT -d 192.168.10.81 -p tcp --dport 22 -m connlimit --connlimit-above 2 -j REJECT

3.4.2.7 limit 扩展

基于收发报文的速率做匹配 , 令牌桶过滤器

--limit-burst number #前多少个包不限制
--limit #[/second(秒)|/minute(分)|/hour(时)|/day(天)]  #前面加数字表示每多少过多少个包

范例:

[13:46:19 root@centos8 ~]#iptables -A INPUT -p icmp -m limit --limit-burst 10 --limit 20/minute -j ACCEPT
[13:48:22 root@centos8 ~]#iptables -AINPUT -p icmp -j REJECT
[13:48:34 root@centos8 ~]#ping 192.168.10.81

3.4.2.8 state 扩展(重点)

state 扩展模块,可以根据”连接追踪机制“去检查连接的状态,较耗资源

conntrack 机制:追踪本机上的请求和响应之间的关系

状态类型

  • NEW:新发出请求;连接追踪信息库中不存在此连接的相关信息条目,因此,将其识别为第一次发出的请求
  • ESTABLISHED:NEW 状态之后,连接追踪信息库中为其建立的条目失效之前期间内所进行的通信状态
  • RELATED:新发起的但与已有连接相关联的连接,如:ftp 协议中的数据连接与命令连接之间的关系
  • INVALID:无效的连接,如 flag 标记不正确
  • UNTRACKED:未进行追踪的连接,如:raw 表中关闭追踪

已经追踪到的并记录下来的连接信息库

[14:12:14 root@centos8 ~]#cat /proc/net/nf_conntrack
ipv4     2 tcp      6 46 CLOSE_WAIT src=192.168.10.81 dst=192.168.10.82 sport=22 dport=49282 src=192.168.10.82 dst=192.168.10.81 sport=49282 dport=22 [ASSURED] mark=0 zone=0 use=2
ipv4     2 tcp      6 299 ESTABLISHED src=192.168.10.81 dst=192.168.10.1 sport=22 dport=57028 src=192.168.10.1 dst=192.168.10.81 sport=57028 dport=22 [ASSURED] mark=0 zone=0 use=2

调整连接追踪功能所能够容纳的最大连接数量

[14:12:36 root@centos8 ~]#cat /proc/sys/net/netfilter/nf_conntrack_max
30720
[14:13:42 root@centos8 ~]#cat /proc/sys/net/nf_conntrack_max
30720

查看连接跟踪有多少条目

[14:13:54 root@centos8 ~]#cat /proc/sys/net/netfilter/nf_conntrack_count
1

不同的协议的连接追踪时长

[14:15:16 root@centos8 ~]#ll /proc/sys/net/netfilter/

说明:

  • 连接跟踪,需要加载模块: modprobe nf_conntrack_ipv4
  • 当服务器连接多于最大连接数时 dmesg 可以观察到 :kernel: ip_conntrack: table full, dropping packet 错误,并且导致建立 TCP 连接很慢。
  • 各种状态的超时后,链接会从表中删除

范例:面试题

[14:17:21 root@centos8 ~]#echo 1 >/proc/sys/net/netfilter/nf_conntrack_max
[14:17:51 root@centos8 ~]#tail -f /var/log/messages
Jan 24 14:18:05 centos8 kernel: nf_conntrack: nf_conntrack: table full, dropping packet
[root@centos6 ~]#tail /var/log/messages
Jul  8 09:51:16 centos6 kernel: nf_conntrack: table full, dropping packet.

连接过多的解决方法两个:

(1) 加大 nf_conntrack_max 值

vi /etc/sysctl.conf
net.nf_conntrack_max = 393216
net.netfilter.nf_conntrack_max = 393216

(2) 降低 nf_conntrack timeout 时间

vi /etc/sysctl.conf
net.netfilter.nf_conntrack_tcp_timeout_established = 300
net.netfilter.nf_conntrack_tcp_timeout_time_wait = 120
net.netfilter.nf_conntrack_tcp_timeout_close_wait = 60
net.netfilter.nf_conntrack_tcp_timeout_fin_wait = 120
iptables -t nat -L -n

格式:

[!] --state state

范例: 不允许 192.168.82 访问本机,但本机可以访问 192.168.10.82

[14:59:13 root@centos8 ~]#iptables -AINPUT -m state --state ESTABLISHED,RELATED -j ACCEPT
[14:59:13 root@centos8 ~]#iptables -RINPUT 2 -s 192.168.10.82 -j REJECT

3.5 target

target 包括以下类型:

自定义链, ACCEPT, DROP, REJECT,RETURN,LOG,SNAT,DNAT,REDIRECT,MASQUERADE
LOG:非中断target,本身不拒绝和允许,放在拒绝和允许规则前,并将日志记录在/var/log/messages系
统日志中
--log-level level   级别: debug,info,notice, warning, error, crit, alert,emerg
--log-prefix prefix 日志前缀,用于区别不同的日志,最多29个字符

范例:访问记录日志

[15:07:37 root@centos8 ~]#iptables -AINPUT -s192.168.10.0/24 -p tcp --dport 80 -m state --state NEW -j LOG --log-prefix "new connections:"
[15:07:50 root@centos8 ~]#tail -1 /var/log/messages
Jan 24 15:07:20 centos8 kernel: new connections:IN=eth0 OUT= MAC=00:0c:29:62:36:f5:00:0c:29:1a:4b:7f:08:00 SRC=192.168.10.82 DST=192.168.10.81 LEN=60 TOS=0x00 PREC=0x00 TTL=64 ID=61055 DF PROTO=TCP SPT=32886 DPT=80 WINDOW=29200 RES=0x00 SYN URGP=0

3.6 规则优化最佳实践

  1. 安全放行所有入站和出站的状态为 ESTABLISHED 状态连接,建议放在第一条,效率更高
  2. 谨慎放行入站的新请求
  3. 有特殊目的限制访问功能,要在放行规则之前加以拒绝
  4. 同类规则(访问同一应用,比如:http ),匹配范围小的放在前面,用于特殊处理
  5. 不同类的规则(访问不同应用,一个是 http,另一个是 mysql ),匹配范围大的放在前面,效率更高
-s 10.0.0.6 -p tcp --dport 3306 -j REJECT
-s 172.16.0.0/16 -p tcp --dport 80 -j REJECT
  1. 应该将那些可由一条规则能够描述的多个规则合并为一条,减少规则数量,提高检查效率
  2. 设置默认策略,建议白名单(只放行特定连接)
  • iptables -P,不建议,容易出现“自杀现象”
  • 规则的最后定义规则做为默认策略,推荐使用,放在最后一条

3.7 iptables 规则保存

使用 iptables 命令定义的规则,手动删除之前,其生效期限为 kernel 存活期限

持久保存规则:

CentOS 7,8

iptables-save > /PATH/TO/SOME_RULES_FILE

CentOS 6

#将规则覆盖保存至/etc/sysconfig/iptables文件中
service iptables save

加载规则

CentOS 7,8 重新载入预存规则文件中规则:

iptables-restore < /PATH/FROM/SOME_RULES_FILE

iptables-restore 选项

-n, --noflush:不清除原有规则
-t, --test:仅分析生成规则集,但不提交

CentOS 6:

#会自动从/etc/sysconfig/iptables 重新载入规则
service iptables  restart

开机自动重载规则

  • 用脚本保存各 iptables 命令;让此脚本开机后自动运行 /etc/rc.d/rc.local 文件中添加脚本路径 /PATH/TO/SOME_SCRIPT_FILE
  • 用规则文件保存各规则,开机时自动载入此规则文件中的规则在/etc/rc.d/rc.local 文件添加
iptables-restore < /PATH/FROM/IPTABLES_RULES_FILE

3.8 网络防火墙

iptables/netfilter 利用 filter 表的 FORWARD 链,可以充当网络防火墙:

注意的问题:

(1) 请求-响应报文均会经由 FORWARD 链,要注意规则的方向性

(2) 如果要启用 conntrack 机制,建议将双方向的状态为 ESTABLISHED 的报文直接放行

3.8.1 FORWARD 链实现内外网络的流量控制

范例: 实现内网访问可以访问外网,反之禁止

clipboard.png

#环境准备
[15:59:55 root@centos8 ~]#hostname -I
172.16.10.71 
[16:01:41 root@centos8 ~]#route -n
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
0.0.0.0         172.16.10.81    0.0.0.0         UG    100    0        0 eth0
172.16.10.0     0.0.0.0         255.255.255.0   U     100    0        0 eth0


[15:57:40 root@centos8 ~]#hostname -I
192.168.10.81 172.16.10.81 
[16:02:29 root@centos8 ~]#echo 1 >/proc/sys/net/ipv4/ip_forward

[15:59:23 root@centos7 ~]#hostname -I
192.168.10.71 
[16:02:59 root@centos7 ~]#route -n
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
0.0.0.0         192.168.10.81   0.0.0.0         UG    100    0        0 eth0
192.168.10.0    0.0.0.0         255.255.255.0   U     100    0        0 eth0

[15:59:07 root@centos7 ~]#hostname -I
192.168.10.72 
[16:03:07 root@centos7 ~]#route -n
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
0.0.0.0         192.168.10.81   0.0.0.0         UG    100    0        0 eth0
192.168.10.0    0.0.0.0         255.255.255.0   U     100    0        0 eth0

#方法1 通过标准模块实现内网访问外网特定服务http和icmp,反之禁止
[16:15:31 root@frewall ~]#iptables -AFORWARD -j REJECT
[16:15:58 root@frewall ~]#iptables -IFORWARD -s 192.168.10.0/24 -p tcp --sport 80 -j ACCEPT
[16:16:46 root@frewall ~]#iptables -IFORWARD -d 192.168.10.0/24 -p tcp --dport 80 -j ACCEPT
[16:17:04 root@frewall ~]#iptables -IFORWARD -s 192.168.10.0/24 -p icmp --icmp-type 8 -j ACCEPT
[16:20:46 root@frewall ~]#iptables -IFORWARD -d 192.168.10.0/24 -p icmp --icmp-type 0 -j ACCEPT
[16:21:52 root@frewall ~]#iptables -vnL --line-numbers
Chain FORWARD (policy ACCEPT 0 packets, 0 bytes)
num   pkts bytes target     prot opt in     out     source               destination       
1        2   168 ACCEPT     icmp --  *      *       0.0.0.0/0            192.168.10.0/24      icmptype 0
2        2   168 ACCEPT     icmp --  *      *       192.168.10.0/24      0.0.0.0/0            icmptype 8
3       18  1191 ACCEPT     tcp  --  *      *       0.0.0.0/0            192.168.10.0/24      tcp dpt:80
4       12  1431 ACCEPT     tcp  --  *      *       192.168.10.0/24      0.0.0.0/0            tcp spt:80
5        2   168 REJECT     all  --  *      *       0.0.0.0/0            0.0.0.0/0            reject-with icmp-port-unreachable
#方法2 利用state模块实现内网访问可以访问外网,反之禁止,但是外网可以访问内网特定服务http服务
[16:58:48 root@frewall ~]#iptables -AFORWARD ! -s 192.168.10.0/24 -d 192.168.10.0/24 -j REJECT
[16:59:29 root@frewall ~]#iptables -IFORWARD ! -s 192.168.10.0/24  -m state --state ESTABLISHED,RELATED -j ACCEPT
[17:03:22 root@frewall ~]#iptables -IFORWARD 2 ! -s 192.168.10.0/24 -p tcp --dport 80 -j ACCEPT

3.8.2 NAT 表(重点)

clipboard.png

NAT: network address translation,支持 PREROUTING,INPUT,OUTPUT,POSTROUTING 四个链

请求报文:修改源/目标 IP,由定义如何修改

响应报文:修改源/目标 IP,根据跟踪机制自动实现

NAT 的实现分为下面类型:

  • SNAT:source NAT ,支持 POSTROUTING, INPUT,让本地网络中的主机通过某一特定地址访问外部网络,实现地址伪装,请求报文:修改源 IP
  • DNAT:destination NAT 支持 PREROUTING , OUTPUT,把本地网络中的主机上的某服务开放给外部网络访问(发布服务和端口映射),但隐藏真实 IP,请求报文:修改目标 IP
  • PNAT: port nat,端口和 IP 都进行修改

3.8.3 SNAT

SNAT:基于 nat 表的 target,适用于固定的公网 IP

SNAT 选项:

  • --to-source [ipaddr[-ipaddr]][:port[-port]]
  • --random
iptables -t nat -A POSTROUTING -s LocalNET ! -d LocalNet -j SNAT --to-source ExtIP

注意: 需要开启 ip_forward

范例:

iptables -t nat -A POSTROUTING -s 10.0.1.0/24 ! –d 10.0.1.0/24 -j SNAT --to-source 172.18.1.6-172.18.1.9

MASQUERADE:基于 nat 表的 target,适用于动态的公网 IP,如:拨号网络,就是网卡的公网 IP 不固定是动态获取的

MASQUERADE 选项:

  • --to-ports port[-port]
  • --random
iptables -t nat -A POSTROUTING -s LocalNET ! -d LocalNet -j MASQUERADE

范例:

iptables -t nat -A POSTROUTING -s 10.0.1.0/24 ! –d 10.0.1.0/24 -j MASQUERADE

范例:查看本地主机访问公网时使用的 IP

[17:05:09 root@frewall ~]#curl ip.sb
110.17.5.83

3.8.2.1 范例:SNAT(重点)

clipboard.png

跟上面环境差不多,但是外部网络主机没有网关

一定要启用路由转发
#针对专线静态公共IP
[17:14:20 root@frewall ~]#iptables -t nat -A POSTROUTING -s 192.168.10.0/24 -j SNAT --to-source 172.16.10.81
#针对拨号网络和专线静态公共IP
[17:26:12 root@frewall ~]#iptables -t nat -APOSTROUTING -s 192.168.10.0/24 -j MASQUERADE
#查看监听端口
[17:26:52 root@frewall ~]#ss -ntl
State        Recv-Q       Send-Q              Local Address:Port               Peer Address:Port     
LISTEN       0            128                       0.0.0.0:111                     0.0.0.0:*        
LISTEN       0            128                       0.0.0.0:22                      0.0.0.0:*        
LISTEN       0            128                          [::]:111                        [::]:*        
LISTEN       0            128                          [::]:22                         [::]:* 
#内网可以访问外网
[17:31:36 root@centos7 ~]#curl 172.16.10.71
internet
#外网不可以访问内网
[17:31:42 root@centos8 ~]#curl 192.168.10.71
curl: (7) Couldn't connect to server
#在外网服务器查看到是firewalld的地址在访问
[17:32:34 root@centos8 ~]#tail /var/log/httpd/access_log 
172.16.10.81 - - [24/Jan/2021:17:31:46 +0800] "GET / HTTP/1.1" 200 9 "-" "curl/7.29.0"
#查看转换状态信息
[17:34:06 root@frewall ~]#cat /proc/net/nf_conntrack
ipv4     2 tcp      6 117 TIME_WAIT src=192.168.10.71 dst=172.16.10.71 sport=52598 dport=80 src=172.16.10.71 dst=172.16.10.81 sport=80 dport=52598 [ASSURED] mark=0 zone=0 use=2

3.8.4 DNAT

DNAT:nat 表的 target,适用于端口映射,即可重定向到本机,也可以支持重定向至不同主机的不同端口,但不支持多目标,即不支持负载均衡功能

DNAT 选项:

  • --to-destination [ipaddr[-ipaddr]][:port[-port]]
帮助查看
[17:34:12 root@frewall ~]#man iptables-extensions

DNAT 格式:

iptables -t nat -A PREROUTING -d ExtIP -p tcp|udp --dport PORT -j DNAT --to-destination InterSeverIP[:PORT]

注意需要开启 ip_forward

范例:DNAT
clipboard.png

[17:41:04 root@frewall ~]#iptables -t nat -A PREROUTING -d 172.16.10.81 -p tcp --dport 80 -j DNAT --to-destination 192.168.10.71:80
[17:41:12 root@frewall ~]#ss -ntl
State        Recv-Q       Send-Q              Local Address:Port               Peer Address:Port     
LISTEN       0            128                       0.0.0.0:111                     0.0.0.0:*        
LISTEN       0            128                       0.0.0.0:22                      0.0.0.0:*        
LISTEN       0            128                          [::]:111                        [::]:*        
LISTEN       0            128                          [::]:22                         [::]:*  
[17:33:03 root@centos8 ~]#curl 172.16.10.81
192.168.10.71 httpd
[17:34:10 root@centos7 ~]#tail /var/log/httpd/access_log 
172.16.10.71 - - [24/Jan/2021:16:10:29 +0800] "GET / HTTP/1.1" 200 20 "-" "curl/7.61.1"、
[17:43:49 root@frewall ~]#cat /proc/net/nf_conntrack
ipv4     2 udp      17 27 src=192.168.10.71 dst=192.168.10.81 sport=45053 dport=123 src=192.168.10.81 dst=192.168.10.71 sport=123 dport=45053 mark=0 zone=0 use=2
ipv4     2 tcp      6 117 TIME_WAIT src=172.16.10.71 dst=172.16.10.81 sport=57170 dport=80 src=192.168.10.71 dst=172.16.10.71 sport=80 dport=57170 [ASSURED] mark=0 zone=0 use=2
ipv4     2 tcp      6 299 ESTABLISHED src=192.168.10.81 dst=192.168.10.1 sport=22 dport=59552 src=192.168.10.1 dst=192.168.10.81 sport=59552 dport=22 [ASSURED] mark=0 zone=0 use=2

范例:

如果目标访问的端口和自己主机的端口一致最后可以不写
[17:48:02 root@frewall ~]#iptables -t nat -A PREROUTING -s 0/0 -d 172.16.10.81 -p tcp --dport 80 -j DNAT --to-destination 192.168.10.71
也可以把原本的端口代理到其他端口
[17:49:22 root@frewall ~]#iptables -t nat -R PREROUTING 2 -s 0/0 -d 172.16.10.81 -p tcp --dport 80 -j DNAT --to-destination 192.168.10.72:8080
注意代理端口的话使用ss命令是看不到端口监听的只要应用或者进程才可以打开监听端口,iptables是内核中的操作

3.8.5 REDIRECT 转发

REDIRECT,是 NAT 表的 target,通过改变目标 IP 和端口,将接受的包转发至同一个主机的不同端口,可用于 PREROUTING OUTPUT 链

REDIRECT 选项:

  • --to-ports port[-port]

注意: 无需开启 ip_forward,一般用于本机端口转发

范例:

iptables -t nat -A PREROUTING -d 172.16.100.10 -p tcp --dport 80 -j REDIRECT --to-ports 8080

范例:

[17:42:27 root@centos7 ~]#ss -ntl
State       Recv-Q Send-Q      Local Address:Port                     Peer Address:Port
LISTEN      0      128                     *:111                                 *:*
LISTEN      0      128                     *:22                                  *:*
LISTEN      0      100             127.0.0.1:25                                  *:*
LISTEN      0      128                  [::]:111                              [::]:*
LISTEN      0      128                  [::]:80                               [::]:*
LISTEN      0      128                  [::]:22                               [::]:*
LISTEN      0      100                 [::1]:25                               [::]:*
[18:06:02 root@centos7 ~]#iptables -t nat -APREROUTING -p tcp --dport 8000 -j REDIRECT --to-ports 80
[17:45:54 root@centos7 ~]#curl 192.168.10.71:8000
192.168.10.71 httpd
  • Linux

    Linux 是一套免费使用和自由传播的类 Unix 操作系统,是一个基于 POSIX 和 Unix 的多用户、多任务、支持多线程和多 CPU 的操作系统。它能运行主要的 Unix 工具软件、应用程序和网络协议,并支持 32 位和 64 位硬件。Linux 继承了 Unix 以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。

    943 引用 • 943 回帖

相关帖子

回帖

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...