0

0

Linux如何配置iptables端口转发规则_LinuxNAT配置完整操作

舞夢輝影

舞夢輝影

发布时间:2025-11-21 23:50:02

|

533人浏览过

|

来源于php中文网

原创

答案:Linux中通过iptables结合netfilter实现端口转发,需开启IP转发、配置DNAT和SNAT规则,并保存策略。具体步骤为:修改/proc/sys/net/ipv4/ip_forward或sysctl.conf启用转发;使用iptables -t nat -A PREROUTING设置DNAT将外部请求映射到内网主机;在POSTROUTING链添加MASQUERADE或SNAT确保回包正确;最后保存规则至/etc/iptables/rules.v4并配置开机加载,确保网络连通性后转发生效。

linux如何配置iptables端口转发规则_linuxnat配置完整操作

Linux系统中配置iptables端口转发,本质是利用netfilter框架中的NAT(网络地址转换)功能,实现将进入本机某一端口的流量转发到内网其他主机。这种技术常用于搭建简易网关、暴露内网服务或实现负载均衡。以下是完整操作流程。

开启内核IP转发功能

在配置规则前,必须确保Linux内核允许数据包转发。该设置位于/proc/sys/net/ipv4/ip_forward文件中。

临时开启(重启失效):

echo 1 > /proc/sys/net/ipv4/ip_forward

永久生效需修改配置文件

编辑 /etc/sysctl.conf,确保包含以下行:

net.ipv4.ip_forward = 1

保存后执行 sysctl -p 使配置立即生效。

添加DNAT规则实现端口转发

使用iptables的nat表PREROUTING链,对进入的数据包做目标地址转换(DNAT)。例如:将本机公网IP的2222端口流量转发到内网192.168.1.100的22端口。

命令如下:

  • iptables -t nat -A PREROUTING -p tcp --dport 2222 -j DNAT --to-destination 192.168.1.100:22

说明:

PodLM
PodLM

PodLM是一款强大的AI播客生成工具

下载
  • -t nat:指定nat表
  • -A PREROUTING:追加规则到PREROUTING链
  • -p tcp:协议为TCP(如需UDP则改为udp)
  • --dport 2222:外部访问端口
  • --to-destination:指定转发目标IP和端口

配置SNAT或MASQUERADE保证回包正确

若目标主机不在同一广播域,或网关非默认路由,需配置源地址转换(SNAT),确保响应能返回防火墙并转发回去。

常见做法是在POSTROUTING链添加MASQUERADE规则:

  • iptables -t nat -A POSTROUTING -d 192.168.1.100 -p tcp --dport 22 -j MASQUERADE

或更精确地使用SNAT:

  • iptables -t nat -A POSTROUTING -d 192.168.1.100 -p tcp --dport 22 -j SNAT --to-source 本机内网IP

MASQUERADE适用于动态IP环境,SNAT更适合固定IP场景。

保存规则并设置开机加载

iptables规则默认不持久,重启后丢失。需手动保存。

CentOS/RHEL系统:

  • service iptables save

或使用:

  • iptables-save > /etc/iptables/rules.v4

Ubuntu/Debian系统建议安装iptables-persistent

  • apt install iptables-persistent -y
  • iptables-save > /etc/iptables/rules.v4

确保开机自动加载规则。

基本上就这些。确认防火墙未阻断相关端口,且目标主机网络可达,端口监听正常,转发即可生效。

相关专题

更多
tcp和udp的区别
tcp和udp的区别

TCP和UDP的区别,在连接性、可靠性、速度和效率、数据报大小以及适用场景等方面。本专题为大家提供tcp和udp的区别的相关的文章、下载、课程内容,供大家免费下载体验。

118

2023.07.25

udp是什么协议
udp是什么协议

UDP是OSI参考模型中一种无连接的传输层协议。本专题为大家带来udp是什么协议的相关文章,免费提供给大家。

275

2023.08.08

tcp和udp有什么区别
tcp和udp有什么区别

tcp和udp的区别有:1、udp是无连接的,tcp是面向连接的;2、udp是不可靠传输,tcp是可靠传输;3、udp是面向报文传输,tcp是面向字节流传输。想了解更多tcp相关的内容,可阅读本专题下面的相关文章。

360

2024.11.14

磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1347

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

700

2023.06.29

linux find
linux find

find是linux命令,它将档案系统内符合 expression 的档案列出来。可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来。find根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部分为 path,之后的是 expression。还有指DOS 命令 find,Excel 函数 find等。本站专题提供linux find相关教程文章,还有相关

294

2023.06.30

linux修改文件名
linux修改文件名

本专题为大家提供linux修改文件名相关的文章,这些文章可以帮助用户快速轻松地完成文件名的修改工作,大家可以免费体验。

776

2023.07.05

linux系统安装教程
linux系统安装教程

linux系统是一种可以免费使用,自由传播,多用户、多任务、多线程、多CPU的操作系统。本专题提供linux系统安装教程相关的文章,大家可以免费体验。

571

2023.07.06

Golang 分布式缓存与高可用架构
Golang 分布式缓存与高可用架构

本专题系统讲解 Golang 在分布式缓存与高可用系统中的应用,涵盖缓存设计原理、Redis/Etcd集成、数据一致性与过期策略、分布式锁、缓存穿透/雪崩/击穿解决方案,以及高可用架构设计。通过实战案例,帮助开发者掌握 如何使用 Go 构建稳定、高性能的分布式缓存系统,提升大型系统的响应速度与可靠性。

58

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Node.js 教程
Node.js 教程

共57课时 | 8.2万人学习

Vue 教程
Vue 教程

共42课时 | 6.2万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号