标签:DNAT 转发 端口 dev skb forward 数据包
问题:
端口转发,内网设备2的端口5555绑定WAN端口2222。内网设备1访问WAN口端口2222,在桥上pre链执行了DNAT操作,但是数据包最终未转发到内网设备2的5555端口上。如果开启tcpdump抓包工具就正常转发,关闭后还是无法转发。
原因分析:
内核的桥代码在处理pre链上的数据包DNAT后,不会将数据包传到上层IP栈上,也就不会再过forward链。个人觉得数据包在做DNAT后被桥转飞了。
修改:
br_netfilter.c
static int br_nf_pre_routing_finish(struct sk_buff *skb)
if (skb_dst(skb)->dev == dev) {
修改为如下
if (0) {//(skb_dst(skb)->dev == dev) {
标签:DNAT,转发,端口,dev,skb,forward,数据包 来源: https://blog.csdn.net/dashanque/article/details/122351910
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。