LINUX端口转发配置教程:iptables与firewalld详解
时间:2026-01-16 23:55:34 155浏览 收藏
你在学习文章相关的知识吗?本文《LINUX端口转发配置:iptables与firewalld详解》,主要介绍的内容就涉及到,如果你想提升自己的开发能力,就不要错过这篇文章,大家要知道编程理论基础和实战操作都是不可或缺的哦!
首先开启IP转发并配置iptables或firewalld规则,例如使用iptables -t nat -A PREROUTING将8080端口流量转发至192.168.1.100:80,并通过firewall-cmd --add-forward-port实现相同功能,最后用tcpdump和nc验证连通性。

如果您需要在LINUX系统中将一个网络端口的流量重定向到另一个端口或另一台主机,可以通过配置防火墙规则实现端口转发。这种操作常用于服务迁移、负载均衡或绕过网络限制。
本文运行环境:Dell PowerEdge服务器,Ubuntu 22.04
一、使用iptables配置端口转发
iptables是LINUX内核中经典的包过滤工具,通过修改其规则链可以实现灵活的端口映射功能。启用端口转发前需确保系统允许IP转发,并在nat表中添加PREROUTING和POSTROUTING规则。
1、开启系统的IP转发功能,编辑网络配置文件/etc/sysctl.conf,确保包含以下内容:net.ipv4.ip_forward = 1。
2、执行命令sysctl -p以重新加载配置并激活IP转发。
3、使用iptables命令添加PREROUTING规则,将进入本机某端口的流量重定向至目标地址,例如:iptables -t nat -A PREROUTING -p tcp --dport 8080 -j DNAT --to-destination 192.168.1.100:80。
4、若目标地址不在本地网络,需添加SNAT规则以便正确返回响应:iptables -t nat -A POSTROUTING -j MASQUERADE。
5、保存当前规则防止重启后丢失,在Debian/Ubuntu系统中可使用iptables-save > /etc/iptables/rules.v4命令持久化规则。
二、使用firewalld配置端口映射
firewalld是现代主流LINUX发行版默认的动态防火墙管理器,支持区域(zone)和服务级别的配置方式。通过其富规则(rich rules)或直接接口可完成端口转发设置。
1、确认firewalld服务正在运行:systemctl status firewalld,若未启动则使用systemctl start firewalld启用。
2、选择需要应用规则的网络区域,通常为public,可通过firewall-cmd --get-default-zone查看默认区域。
3、执行端口转发配置命令,例如将本机的80端口流量转发至内部IP 192.168.1.50的8080端口:firewall-cmd --add-forward-port=port=80:proto=tcp:toaddr=192.168.1.50:toport=8080 --permanent。
4、若仅指定toaddr而省略toport,则默认转发到相同端口号的目标设备。
5、重新加载firewalld配置使规则生效:firewall-cmd --reload。
6、验证规则是否成功添加:firewall-cmd --list-all,输出中应包含forward-port条目。
三、验证端口转发是否生效
完成配置后必须进行连通性测试,确保数据流按预期路径传输。可通过外部客户端访问前端端口并观察后端服务日志或使用抓包工具分析流量走向。
1、从远程主机使用telnet或nc命令测试目标端口是否开放,例如:nc -zv your_server_ip 8080。
2、在目标服务器上监听相关端口,确认接收到的数据来自原始客户端或经由NAT处理后的网关地址。
3、使用tcpdump工具捕获关键接口上的数据包,如:tcpdump -i eth0 port 80 and host 192.168.1.100,检查是否有请求到达。
4、查看服务进程是否正常接收连接,使用ss -tulnp | grep :确认服务监听状态。
理论要掌握,实操不能落!以上关于《LINUX端口转发配置教程:iptables与firewalld详解》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
145 收藏
-
301 收藏
-
284 收藏
-
249 收藏
-
137 收藏
-
420 收藏
-
377 收藏
-
102 收藏
-
169 收藏
-
437 收藏
-
376 收藏
-
168 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习