内核无法转发交换机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

相关推荐
不会写DN35 分钟前
其实跨域问题是后端来解决的? CORS
服务器·网络·面试·go
Harvy_没救了38 分钟前
【网络架构】Keepalived + LVS(DR) + MariaDB 双主备实践
网络·架构·lvs
大鹏说大话6 小时前
SSL证书自动化的未来:ACME协议与Let’s Encrypt实践
网络·安全
被摘下的星星7 小时前
网际协议(IP协议)
网络·tcp/ip
爱学习的小囧8 小时前
ESXi VMkernel 端口 MTU 最佳设置详解
运维·服务器·网络·php·虚拟化
TechubNews10 小时前
Base 发布首个独立 OP Stack 框架的网络升级 Azul,将是 L2 自主迭代的开端?
大数据·网络·人工智能·区块链·能源
Chockmans11 小时前
图片马合成保姆级教程
web安全·网络安全·系统安全·网络攻击模型·安全威胁分析·安全架构·春秋云境
多年小白11 小时前
中科院 Ouroboros 晶圆级存算一体芯片深度解析
大数据·网络·人工智能·科技·ai
发光小北11 小时前
IEC104 转 Modbus TCP 网关如何应用?
网络·网络协议·tcp/ip
Chengbei1112 小时前
红队专属Bing Dork自动化工具,敏感信息侦察效率拉满、自动生成可视化信息泄露审计报告
java·人工智能·安全·web安全·网络安全·自动化·系统安全