iptables/netfilter网络防火墙实现及实战分析

本文涉及的产品
云解析 DNS,旗舰版 1个月
公网NAT网关,每月750个小时 15CU
全局流量管理 GTM,标准版 1个月
简介:

前提知识

  • 任何主机若要与非同网络中的主机通信,则必须将报文发送到默认网关;

  • 对Linux而言,IP地址是属于主机(内核中)的,不属于网卡,只要属于当前主机的IP地址间,都可直接响应,不称为转发

  • 私有地址在路由器上是不允许被路由的


防火墙的类型与作用的链

  • 主机防火墙:一般使用INPUT,OUTPUT链来过滤进入和发出的报文

  • 网络防火墙:一般使用PREROUTING,FORWARD,POSTROUTING链来转发经过的报文


不同网络间主机通信的方式

路由

对于Linux主机,设定/proc/sys/net/ipv4/ip_forward的值为1,即开启了路由功能,可以作为模拟路由器使用

wKioL1M2qJDgtWVJAAGspjiVuW0909.jpg

注:但真实的路由器还应该存在生成路由表的机制,一般是基于路由协议(如RIP2,OSPF)动态学习的,在此不作讨论

NAT

工作于网络层和传输层,也可分为静态NAT和动态NAT

  • Basic NAT:静态NAT;NAT服务器上有一个外网地址池,内网连接时直接分配一个外网IP使用,很不灵活

  • NAPT:动态NAT,Network Address Port Translation,即网络端口地址转换,也可分为SNAT和DNAT

    • SNAT:源地址转换;适用于内网主机访问互联网,原理图如下:

      wKioL1M2qQjDPBwNAAS9qCPdMFQ935.jpg

    • DNAT:目标地址转换;适用于让互联网主机访问本地内网中的某主机上的服务,原理图如下:

      wKiom1M2qVPD1SQIAAVaGmF2b-Y863.jpg


iptables/netfilter基于SNAT和DNAT原理实现报文转发

  • -j SNAT --to-source SIP

    • 规则添加:在POSTROUTING链上

  • -j MASQUERADE

    • 用于外网IP是ADSL拨号上网时生成的动态IP,MASQUERADE模式能自行查找能访问互联网的外网IP,并完成SNAT

  • -j DNAT --to-destination DIP[:Port]

    • 支持端口映射

    • 规则添加:在PREROUTING链上

实例:

1
2
# 将外网对172.16.100.7:22022的访问转发至内网的192.168.20.12.22
iptables -t nat -A PREROUTING -d 172.16.100.7 -p tcp --dport 22022 -j DNAT --to-destination 192.168.20.12.22



iptables/netfilter实战解析

需求分析

wKiom1M26zqSprGfAAMmc447Atg647.jpg

架构设计

wKioL1M26y_ASnyuAALkUgZwIyc755.jpg

配置部署

DNS Server配置

网络配置

1
2
3
4
5
6
7
8
9
# vi /etc/sysconfig/network-scripts/ifcfg-eth0
DEVICE= "eth0"
BOOTPROTO= "static"
NM_CONTROLLED= "no"
ONBOOT= "yes"
TYPE= "Ethernet"
IPADDR=172.16.251.178
NETMASK=255.255.0.0
GATEWAY=172.16.251.236

DNS主配置文件:/etc/named.conf

1
2
3
4
5
6
7
8
# named.conf中需修改的部分
listen-on port 53 { 127.0.0.1; 172.16.251.178;};
allow-query     { any; };
recursion no;
#zone "." IN {
#   type hint;
#   file "named.ca";
#};

DNS辅助配置文件:/etc/named.rfc1912.zones

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
acl inter_net {
172.16.251.0 /24 ;
};
view inter_net {
match-clients { inter_net; };
         zone  "."  IN {
                 type  hint;
                 file  "named.ca" ;
         };
zone  "jason.com"  IN {
type  master;
file  "jason.com.inter_net" ;
};
};
view outer_net {
match-clients { any; };
zone  "jason.com"  IN {
type  master;
file  "jason.com.outer_net" ;
};
};

区域数据文件

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
# vi /var/named/jason.com.inter_net
$TTL 1D
jason.com. IN SOA dns.jason.com. admin.jason.com (
2014032920 ; serial
1D ; refresh
1H ; retry
1W ; expire
3H ) ; minimum
@ NS dns
dns A 172.16.251.178
www A 172.16.251.182
# vi /var/named/jason.com.outer_net
$TTL 1D
jason.com. IN SOA dns.jason.com. admin.jason.com (
2014032920 ; serial
1D ; refresh
1H ; retry
1W ; expire
3H ) ; minimum
@ NS dns
dns A 172.16.251.178
www A 3.3.3.1

启动named服务

1
2
3
chown  root.named jason.com.inter_net
chown  root.named jason.com.outer_net
service named restart

Web Server配置

1
2
3
4
配置一个虚拟主机,监听端口8080
在DocumentRoot目录下创建一简单的测试文件 test .html,内容随意,如
“Hello Mageedu”
启动httpd服务即可

Firewall配置

网络配置

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
# vi /etc/sysconfig/network-scripts/ifcfg-eth0
DEVICE= "eth0"
BOOTPROTO= "static"
NM_CONTROLLED= "no"
ONBOOT= "yes"
TYPE= "Ethernet"
IPADDR=172.16.251.236
NETMASK=255.255.0.0
GATEWAY=172.16.0.1
# vi /etc/sysconfig/network-scripts/ifcfg-eth1
DEVICE= "eth1"
BOOTPROTO= "static"
NM_CONTROLLED= "no"
ONBOOT= "yes"
TYPE= "Ethernet"
IPADDR=3.3.3.1
NETMASK=255.255.255.0
DNS1=3.3.3.1

注:因为3.3.3.1和3.3.3.3都是模拟的外网IP地址,故对应的网卡应处于同一信道内,且不能和内网的通信信道一致,故在用虚拟机测试时,可将对应内网IP的网卡的网络方式改为桥接,而对应外网IP的网卡的网络方式改为自定义,如vmnet2

添加iptables规则

1
2
iptables -t nat -A PREROUTING -d 3.3.3.1 /32  -p udp --dport 53 -j DNAT --to-destination 172.16.251.178
iptables -t nat -A PREROUTING -d 3.3.3.1 /32  -p tcp --dport 8080 -j DNAT --to-destination 172.16.251.182

Inter Client配置

1
2
3
4
5
6
7
8
9
10
11
12
# vi /etc/sysconfig/network-scripts/ifcfg-eth0
DEVICE= "eth0"
BOOTPROTO= "static"
NM_CONTROLLED= "no"
ONBOOT= "yes"
TYPE= "Ethernet"
IPADDR=172.16.251.176
NETMASK=255.255.255.0
GATEWAY=172.16.251.236
DNS1=172.16.251.178
# vi /etc/resolv.conf
nameserver 172.16.251.178

Outer Client配置

1
2
3
4
5
6
7
8
9
10
11
12
# vi /etc/sysconfig/network-scripts/ifcfg-eth0
DEVICE= "eth0"
BOOTPROTO= "static"
NM_CONTROLLED= "no"
ONBOOT= "yes"
TYPE= "Ethernet"
IPADDR=3.3.3.3
NETMASK=255.255.255.0
GATEWAY=3.3.3.1
DNS1=3.3.3.1
# vi /etc/resolv.conf
nameserver 3.3.3.1

DNS解析测试

wKioL1M27yeguPY3AAEmn_6VUto674.jpg

HTTP访问测试

wKiom1M273CAf5rlAAQtUHrZog8122.jpg

大功告成,哦也!










本文转自 xxrenzhe11 51CTO博客,原文链接:http://blog.51cto.com/xxrenzhe/1386677,如需转载请自行联系原作者
目录
相关文章
|
27天前
|
存储 人工智能 编解码
Deepseek 3FS解读与源码分析(2):网络通信模块分析
2025年2月28日,DeepSeek 正式开源其颠覆性文件系统Fire-Flyer 3FS(以下简称3FS),重新定义了分布式存储的性能边界。本文基于DeepSeek发表的技术报告与开源代码,深度解析 3FS 网络通信模块的核心设计及其对AI基础设施的革新意义。
Deepseek 3FS解读与源码分析(2):网络通信模块分析
|
1月前
|
JSON 前端开发 JavaScript
HarmonyOS NEXT 实战系列10-网络通信
本文介绍了网络通信相关知识,包括HTTP协议的工作原理、鸿蒙系统中HTTP模块的使用方法、Promise异步操作处理机制及async/await语法糖的应用,以及JSON数据格式的语法规则与转换方法。重点讲解了HTTP请求响应流程、鸿蒙开发中的网络权限申请与代码实现、Promise三种状态及创建方式,并通过示例说明异步编程技巧和JSON在数据传递中的应用。
70 10
|
1月前
|
监控 安全 网络协议
Hyper V上网实战:多虚拟机网络环境配置
在Hyper-V环境中配置多虚拟机网络以实现上网功能,需完成以下步骤:1. 确认Hyper-V安装与物理网络连接正常;2. 配置虚拟交换机(外部、内部或专用)以支持不同网络需求;3. 设置虚拟机网络适配器并关联对应虚拟交换机;4. 验证虚拟机网络连接状态;5. 根据场景需求优化多虚拟机网络环境。此外,还需注意网络隔离、性能监控及数据备份等事项,确保网络安全稳定运行。
|
1月前
|
SQL 安全 网络安全
网络安全防御矩阵:从云防火墙流量清洗到WAF语义分析的立体化防护
在数字化浪潮中,网络安全日益重要。云防火墙依托云计算技术,提供灵活高效的网络防护,适用于公有云和私有云环境;Web应用防火墙专注于HTTP/HTTPS流量,防范SQL注入、XSS等攻击,保护Web应用安全。两者结合使用可实现优势互补,构建更强大的网络安全防线,满足不同场景下的安全需求。
54 1
|
1月前
|
机器学习/深度学习 API Python
Python 高级编程与实战:深入理解网络编程与异步IO
在前几篇文章中,我们探讨了 Python 的基础语法、面向对象编程、函数式编程、元编程、性能优化、调试技巧、数据科学、机器学习、Web 开发和 API 设计。本文将深入探讨 Python 在网络编程和异步IO中的应用,并通过实战项目帮助你掌握这些技术。
|
2月前
|
监控 安全 Devops
防火墙是什么?详解网络安全的关键守护者
防火墙是什么?详解网络安全的关键守护者
78 18
|
4月前
|
存储 安全 物联网
浅析Kismet:无线网络监测与分析工具
Kismet是一款开源的无线网络监测和入侵检测系统(IDS),支持Wi-Fi、Bluetooth、ZigBee等协议,具备被动监听、实时数据分析、地理定位等功能。广泛应用于安全审计、网络优化和频谱管理。本文介绍其安装配置、基本操作及高级应用技巧,帮助用户掌握这一强大的无线网络安全工具。
262 9
浅析Kismet:无线网络监测与分析工具
|
3月前
|
弹性计算 安全 网络安全
网络安全如何保障?云防火墙帮您严守边界
云防火墙为企业提供全面的网络安全防护,自动识别并保护EIP、ECS公网IP等资产,防范DDoS、未授权访问和数据泄露。它支持互联网、NET、VPC及主机边界的统一流量管控,符合国家等保规定。首次使用时,用户需配置IPS拦截规则和访问控制策略,确保流量安全。更多功能和福利敬请关注12月11日直播。
|
4月前
|
Kubernetes 安全 Devops
有效抵御网络应用及API威胁,聊聊F5 BIG-IP Next Web应用防火墙
有效抵御网络应用及API威胁,聊聊F5 BIG-IP Next Web应用防火墙
136 10
有效抵御网络应用及API威胁,聊聊F5 BIG-IP Next Web应用防火墙
|
4月前
|
数据采集 机器学习/深度学习 人工智能
基于AI的网络流量分析:构建智能化运维体系
基于AI的网络流量分析:构建智能化运维体系
759 13