
nftables 貌似不支持 ip length - ip hdrlength * 4 - tcp doff * 4 > 0 这种算术操作。
1 birdvdsk 3 天前 via Android 你的具体需求是什么 |
2 SunBK201 OP @birdvdsk 我需要使用 nftables 把包含 payload 的 TCP 数据包 hook 到用户态的 nfqueue 进行处理,之前的做法是对全部的 TCP 数据包进行 hook ,但是性能损耗太大,所以想要加一层过滤。 |
3 birdvdsk 3 天前 via Android 可以利用 tcp 标志位,将 ACK ,PSH ,FIN 等可能携带数据的数据包使用 nftables 过滤。但是话说回来,经过 Linux 网络栈的情况下进行性能优化是比较困难的。 |
4 luojiyin87 3 天前 语法要换成“比较 + 加法/移位”,不必写减法链式公式。 nft add rule inet payload_queue pre ip protocol tcp \ ip length > (ip hdrlength << 2) + (tcp doff << 2) \ queue num 100 bypass |
5 SunBK201 OP @luojiyin87 似乎有语法错误? Error: syntax error, unexpected hdrlength, expecting ')' |
8 unused 3 天前 th -> ih |
10 xqzr 3 天前 |
11 JoeSmith 3 天前 试试 eBPF 呗 |
12 ysc3839 3 天前 via Android 直接用 DPDK 吧? |
13 v1 3 天前 eBPF 解万忧 |
14 maybeonly 2 天前 iptables 倒是有 -m bpf 可以做,不过 nft 说这个不优雅,不要了 要么就上 ebpf 吧,或者 nfqueue/rawsocket 用户态实现 顺便说。用命令行查看计数器这个操作也挺慢的。 |