内核无法转发交换机trunk-udp-分片数据包

内核无法转发由交换机发出的udp分片trunk包

一、拓补图

二、问题及现象描述

1.server无法采集到pc的发送的经SW后带vlan标签的opcda数据(采集方式:pc主动发送UDP数据,server被动接收pc的上送的数据);

2.pc能ping通server;

3.server能收到pc发送的长度为14的UDP数据包;

4.server无法收到pc发送的端口为8200的长度为4747的数据包(PC发出时会分片);

5.将FW换成传统的其他FW,数据能正常通信;

6.通过抓包观察,FW入口能收到分片数据包,出口无法收到分片数据包;

7.FW关闭netfilter模块,能正常通过;

8.FW将/proc/sys/net/bridge/bridge-nf-call-iptables关闭(桥不走netfilter),能正常通过。

三、通过现象得出结论

问题出在FW;

FW无法转发带vlan标签的且分片的UDP数据;属于内核的bug。

四、问题原因

当报文中的协议为802.1q时,未走分片逻辑,导致驱动发送数据包时大于MTU而数据包丢失。如图:

net/bridge/br_netfilter.c

调试信息如下图:

即,skb->protocol协议号为129(0x8100 802.1q),而代码中的htons(ETH_P_IP)为8(0x08 IP协议),导致无法进入分片逻辑;

代码如下图:

五、解决方法:

在走完netfilter过滤后,增加对802.1q的带vlan数据包的逻辑判断,使其能正常将802.1q的数据包分片后转发。如下图:

net/bridge/br_netfilter.c

相关内核文件:net/bridge/br_netfilter.c

函数:br_nf_dev_queue_xmit

相关推荐
猫头虎19 分钟前
如何在浏览器里体验 Windows在线模拟器:2026最新在线windows模拟器资源合集与技术揭秘
运维·网络·windows·系统架构·开源·运维开发·开源软件
不一样的故事1262 小时前
下的 “Wi-Fi参数配置” 列表,但您当前选中的导航菜单项是 “IP规划”。您遇到的 “IP加载不出来” 问题,很可能
网络协议·tcp/ip·华为
古城小栈3 小时前
Rust 网络请求库:reqwest
开发语言·网络·rust
qq_316837756 小时前
IP网段冲突 配置指定ip使用指定的网络接口发送,而不经过默认网关
服务器·网络·tcp/ip
布史6 小时前
Tailscale虚拟私有网络指南
linux·网络
PyHaVolask7 小时前
Linux应急响应深度实战:服务排查、文件审计与敏感目录监控
系统安全·服务器安全·入侵检测·linux应急响应·安全排查·文件审计
枷锁—sha7 小时前
彻底解决 Google Gemini 报错:异常流量与 IP 地址冲突排查指南
网络·网络协议·tcp/ip
Xの哲學7 小时前
深入剖析Linux文件系统数据结构实现机制
linux·运维·网络·数据结构·算法
-To be number.wan7 小时前
经典真题精讲|2010年408统考第34题:文件传输最少需要多久?
网络·计算机网络
逐梦苍穹7 小时前
不用公网 IP,把内网服务安全发布到公网:ZeroNews 快速上手
网络协议·tcp/ip·安全·内网穿透