0

0

nftables 规则加载成功但流量不匹配的 hook/priority 问题

舞姬之光

舞姬之光

发布时间:2026-01-26 19:29:02

|

238人浏览过

|

来源于php中文网

原创

最常见原因是规则挂载到错误hook或priority导致数据包未经过该链;需用nft list ruleset -a确认hook和priority,检查流量是否到达对应hook,并排查更高优先级规则提前终止匹配。

nftables 规则加载成功但流量不匹配的 hook/priority 问题

为什么 nftables 规则加载成功却完全不生效

最常见原因是规则挂载到了错误的 hook 或不匹配的 priority,导致数据包根本没经过这条链。nftables 不像 iptables 那样默认把规则塞进固定链里,它要求你显式指定 hook(如 inputforward)和 priority(决定在该 hook 中的执行顺序)。如果 priority 值被其他内核模块(比如 nf_tables 自带的连接跟踪、或第三方模块如 ebpf 程序)抢占,你的规则可能被跳过。

如何确认规则实际挂载在哪个 hook 和 priority

nft list ruleset -a 查看所有规则及其 handle,重点关注每条链的定义部分,例如:

nft add table inet filter
nft add chain inet filter input { type filter hook input priority 0 \; }

其中 priority 0 表示该链在 input hook 中以优先级 0 插入。注意:priority 是整数,值越小越早执行;负数(如 -200)通常留给 conntrack,正数(如 100)常用于用户自定义策略。

  • priority -200:通常被 nf_conntrack 占用,做连接状态标记
  • priority -100:常用于 nat 相关链(如 prerouting 中的 DNAT)
  • priority 0:标准过滤点,适合大多数 filter 场景
  • priority 100+:较晚执行,可能错过已 drop 的包(比如被前面的 drop 规则拦截了)

流量不匹配 hook 的典型场景

比如你写了这么一条规则:

微信 WeLM
微信 WeLM

WeLM不是一个直接的对话机器人,而是一个补全用户输入信息的生成模型。

下载
nft add rule inet filter output tcp dport 8080 drop

但它对本机发出的 HTTP 请求完全没效果——因为该规则挂在 output hook,而本机访问 localhost:8080 实际走的是 outputloopback 路径,但某些内核版本或配置下,回环流量可能绕过 output hook 的部分子流程。更稳妥的做法是同时检查 outputpostrouting,或改用 socket 层规则(type routetype filter + meta oifname "lo")。

  • 本地进程访问 127.0.0.1:优先检查 output + oifname "lo"
  • 容器间通信(如 docker bridge):注意 forward hook 是否启用,且 net.bridge.bridge-nf-call-iptables=1 可能干扰 nftables
  • IPv6 流量误配 IPv4 链:确保链类型是 inet(支持双)或显式声明 ip6

调试时容易忽略的三个点

加载规则后不生效,别急着重写语法,先盯住这三处:

  • 规则所在链是否绑定了正确的 hookpriority(用 nft list chain ... -a 确认)
  • 目标流量是否真的到达该 hook(用 tcpdump -i any port 8080 看包是否存在,再结合 nft monitor trace 抓匹配路径)
  • 是否有更高优先级的 dropjump 规则提前终止了遍历(比如某条 ct state invalid drop 在你的规则之前)

hook 和 priority 不是“设了就完事”的配置项,它们决定了你的规则在内核网络栈中的物理位置。错一个值,规则就等于不存在。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

395

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

575

2023.08.10

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

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

185

2023.11.24

k8s和docker区别
k8s和docker区别

k8s和docker区别有抽象层次不同、管理范围不同、功能不同、应用程序生命周期管理不同、缩放能力不同、高可用性等等区别。本专题为大家提供k8s和docker区别相关的各种文章、以及下载和课程。

257

2023.07.24

docker进入容器的方法有哪些
docker进入容器的方法有哪些

docker进入容器的方法:1. Docker exec;2. Docker attach;3. Docker run --interactive --tty;4. Docker ps -a;5. 使用 Docker Compose。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

497

2024.04.08

docker容器无法访问外部网络怎么办
docker容器无法访问外部网络怎么办

docker 容器无法访问外部网络的原因和解决方法:配置 nat 端口映射以将容器端口映射到主机端口。根据主机兼容性选择正确的网络驱动(如 host 或 overlay)。允许容器端口通过主机的防火墙。配置容器的正确 dns 服务器。选择正确的容器网络模式。排除主机网络问题,如防火墙或连接问题。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

401

2024.04.08

docker镜像有什么用
docker镜像有什么用

docker 镜像是预构建的软件组件,用途广泛,包括:应用程序部署:简化部署,提高移植性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

438

2024.04.08

http500解决方法
http500解决方法

http500解决方法有检查服务器日志、检查代码错误、检查服务器配置、检查文件和目录权限、检查资源不足、更新软件版本、重启服务器或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

404

2023.11.09

拼多多赚钱的5种方法 拼多多赚钱的5种方法
拼多多赚钱的5种方法 拼多多赚钱的5种方法

在拼多多上赚钱主要可以通过无货源模式一件代发、精细化运营特色店铺、参与官方高流量活动、利用拼团机制社交裂变,以及成为多多进宝推广员这5种方法实现。核心策略在于通过低成本、高效率的供应链管理与营销,利用平台社交电商红利实现盈利。

31

2026.01.26

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
光速学会docker容器
光速学会docker容器

共33课时 | 1.9万人学习

Docker 17 中文开发手册
Docker 17 中文开发手册

共0课时 | 0人学习

极客学院Docker视频教程
极客学院Docker视频教程

共33课时 | 17.9万人学习

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

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