0

0

Linux nftables 的 nat masquerade vs iptables 的 SNAT/DNAT 性能对比 2026

冰川箭仙

冰川箭仙

发布时间:2026-03-05 14:10:46

|

618人浏览过

|

来源于php中文网

原创

masquerade 和 snat 不是一回事,前者是后者的特化形式:masquerade 自动获取出口接口动态ip并隐含启用conntrack端口映射,snat需手动指定固定源地址且不强制端口重写。

linux nftables 的 nat masquerade vs iptables 的 snat/dnat 性能对比 2026

masquerade 和 SNAT 在 nftables 里到底是不是一回事?

不是一回事,但效果高度重叠。在 nftables 中,masqueradesnat 的一个特化形式:它自动读取出口接口的当前 IP 地址(比如 DHCP 分配的动态公网 IP),而 snat 必须显式指定固定源地址。这意味着如果你的出口网卡 IP 会变(如家用宽带、云主机弹性 IP 未绑定),用 snat 就会失效,必须换 masquerade

  • masquerade 隐含启用连接跟踪(conntrack)端口映射,适合小规模 NAT;snat 不强制端口重写,可保留原始端口(需加 to :1024-65535 手动控制)
  • 二者都只能放在 postrouting hook,且仅对已建立连接的**应答包**不重复处理(靠 conntrack 识别)
  • 性能上无本质差异——底层调用的是同一组 Netfilter NAT hooks,masquerade 多一次接口地址查询,但开销可忽略(纳秒级)

nftables 的 DNAT 和 iptables 的 DNAT 行为一致吗?

基本一致,但触发时机和链位置更严格。nftables 要求 DNAT 规则必须定义在 prerouting 链(或 output 链用于本地发起的请求),且必须属于 nat 类型表;iptables 允许在 INPUT 链做“伪 DNAT”,nftables 明确禁止这种用法。

  • 常见错误:nft add rule ip nat prerouting tcp dport 80 redirect to :8080 —— 这是错的,redirect 是本机端口转发,不是 DNAT;DNAT 必须用 dnat to 192.168.1.100:8080
  • DNAT 后,返回包自动完成反向转换,无需额外规则——前提是系统开启 IP 转发(/proc/sys/net/ipv4/ip_forward = 1)且 conntrack 正常工作
  • 如果目标服务在本机,DNAT 到 127.0.0.1 会失败(Linux 内核限制 loopback DNAT),应改用 redirect 或调整服务监听地址

为什么把 iptables 的 SNAT 改成 nftables 后,内网机器上不了网?

最常见原因是漏掉了 masquerade 所依赖的隐含前提:没有启用连接跟踪模块,或规则没加在正确的表和链上。

FlowGPT
FlowGPT

ChatGPT指令大全

下载
  • 检查内核是否加载了必要模块:lsmod | grep nf_nat 应输出 nf_natnf_nat_masquerade_ipv4(IPv4)或 nf_nat_masquerade_ipv6(IPv6)
  • nftables 的 NAT 规则必须放在 ipinet 地址族的 nat 表中;写成 ip6 表却处理 IPv4 流量,或写成 filter 表,规则直接被忽略
  • 典型正确写法:nft add rule ip nat postrouting ip saddr 192.168.1.0/24 oifname "eth0" masquerade —— 注意 oifname 是接口名,不是设备别名(如 ens3 而非 eth0),且不能用通配符(oifname != "lo" 不生效)

大规模并发场景下,masquerade 比 SNAT 更耗资源吗?

不会。两者在 conntrack 表项生成、哈希查找、NAT 转换等关键路径上完全共用同一套 Netfilter 逻辑。真正影响性能的是连接数规模和 conntrack 表大小,而不是用 masquerade 还是 snat

  • 瓶颈通常出现在:/proc/sys/net/netfilter/nf_conntrack_max 设置过小(默认常为 65536),导致新建连接被丢弃,现象是“间歇性无法上网”
  • masquerade 在多出口场景下略慢——每次需要查接口 IP,但现代内核已缓存该值,实际差异在微秒级,远低于 TCP 建连开销
  • 真正要优化的地方是:用 ct state established,related accept 提前放行回程包,避免每包都进 NAT 链;以及关闭不需要的协议跟踪(如禁用 nf_conntrack_ftp 模块)

最容易被忽略的一点:nftables 的 NAT 规则不支持“条件跳转”,所有匹配都必须在一条规则里写死。比如你想对部分源 IP 做 masquerade、另一部分做 snat,不能像 iptables 那样分两条规则靠顺序控制,而必须拆成两个独立规则并确保它们不冲突——否则第二条规则永远不会执行。

相关文章

数码产品性能查询
数码产品性能查询

该软件包括了市面上所有手机CPU,手机跑分情况,电脑CPU,电脑产品信息等等,方便需要大家查阅数码产品最新情况,了解产品特性,能够进行对比选择最具性价比的商品。

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1804

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

593

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2341

2025.12.29

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

45

2026.01.19

点击input框没有光标怎么办
点击input框没有光标怎么办

点击input框没有光标的解决办法:1、确认输入框焦点;2、清除浏览器缓存;3、更新浏览器;4、使用JavaScript;5、检查硬件设备;6、检查输入框属性;7、调试JavaScript代码;8、检查页面其他元素;9、考虑浏览器兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

196

2023.11.24

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

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

1542

2023.06.21

如何安装LINUX
如何安装LINUX

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

716

2023.06.29

linux find
linux find

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

300

2023.06.30

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

4

2026.03.05

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 10.2万人学习

Git 教程
Git 教程

共21课时 | 4万人学习

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

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