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

相关推荐
小北方城市网7 分钟前
Python + 前后端全栈进阶课程(共 10 节|完整版递进式|从技术深化→项目落地→就业进阶,无缝衔接基础课)
大数据·开发语言·网络·python·数据库架构
山上三树1 小时前
task_struct 详解
运维·服务器·网络
sweet丶1 小时前
DNS安全威胁:从劫持、污染到放大攻击的演练
网络协议·安全
传感器与混合集成电路2 小时前
175℃持续工作:专为随钻测量系统设计的高温AC-DC电源
网络·能源
日更嵌入式的打工仔2 小时前
Ehercat代码解析中文摘录<1>
网络·笔记·ethercat
一只鹿鹿鹿2 小时前
网络信息与数据安全建设方案
大数据·运维·开发语言·网络·mysql
航Hang*3 小时前
第五章:网络系统建设与运维(中级)——生成树协议
运维·服务器·网络·笔记·华为·ensp
科技块儿3 小时前
电商风控实战:如何利用访客IP防控有效识别刷d行为?
大数据·网络协议·tcp/ip
@淡 定3 小时前
DDD领域事件详解:抽奖系统实战
开发语言·javascript·网络
陌路204 小时前
简写网络库(2)--封装socket类
linux·服务器·网络