2-iptables

偷得浮生 生而为人 本文由博客端 HTTPS://47.110.149.21 主动推送
本贴最后更新于 306 天前,其中的信息可能已经渤澥桑田

3 iptables

3.1 iptables 规则说明

3.1.1 iptables 规则组成

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

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

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

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

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

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

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

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

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:指定表
  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. 匹配条件
  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]]

扩展模块的使用帮助:

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 机制:追踪本机上的请求和响应之间的关系

状态类型

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

[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/

说明:

范例:面试题

[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. 设置默认策略,建议白名单(只放行特定连接)

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-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 的实现分为下面类型:

3.8.3 SNAT

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

SNAT 选项:

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 选项:

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 选项:

帮助查看
[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 选项:

注意: 无需开启 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 以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。

    842 引用 • 907 回帖 • 237 关注
回帖

欢迎来到这里!

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

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