linux不适合数据传输,【Linux调试经验】局域网内数据传输不经过路由

问题/发现:

本人在为一款路由器写一个统计局域网互传流量的Linux内核模块的时候,发现如下问题:

局域网内的一台设备和该局域网内另一台设备进行通信时,我在路由器的netfilter链表处设下钩子,以捕获数据。后来发现这些数据没有经过netfliter,而是直接投递到对方网卡上的。

设备物理连接图如下:

e30a6b69643fe7d3a688c12c858ade84.png

解释:

看似 个人手机 和 个人PC 这两台设备交换数据时 数据包“经由”了路由器,实际上,数据包如下图所示:

0d1f9a32e17b2908ba659e139f02000d.png

当设备 个人手机 想发送数据到 个人PC时,流程如下:

1. 个人手机 发送数据,数据无线传输到路由器 2.4GWiFi

2. 数据向 个人PC 和 路由器br0网卡 各投递一份

3.1 路由器br0网卡 对比数据包MAC字段,发现该数据包不是发往自己的,丢弃

3.2 个人PC 收到数据包,对比数据包MAC字段,发现和自己MAC匹配,送往内部。

流程如上所述,而我在路由器netfilter链设下“埋伏”想捕获数据的做法无异于海底捞月。

验证:

抓包分析如下图所示,个人手机 数据包目的地址直接是 个人PC 的MAC地址,而不是 路由器br0网卡 的MAC地址,所以在路由器端是捕获不到这些数据包的。

==================================================================================

以下内容为arvik在本篇博客写出几日后追加

更改时间:2016/03/14

作者:arvik

最终解决:

经过几日的思索,arvik最终一步步解决了问题。

解决思路:

局域网设备数据包互传是不经过路由器的,那怎么才能统计这些流量呢? 由上面的解释可知,数据包没有进入路由器br0网卡,所以关键问题就是让这些非本地的数据包能进入网卡。

实际上网卡是有这个功能的!

网卡一般有四种模式:

广播方式:该模式下的网卡能够接收网络中的广播信息。

组播方式:设置在该模式下的网卡能够接收组播数据。

直接方式:在这种模式下,只有目的网卡才能接收该数据。

混杂模式:在这种模式下的网卡能够接收一切通过它的数据,而不管该数据是否

是传给它的。

将网卡设置为混杂模式即可,如下:

将eth0设置成混杂模式

ifconfig br0 promisc

取消混杂命令如下:

ifconfig br0 -promisc

此时,局域网所有数据包都能进入路由器br0网卡。但是我们在netfilter还是不能统计,需将这些数据包引入netfilter结构,此时就需要稍微更改Linux内核代码了。更改如下:

在Linux内核源代码 /net/ipv4/ip_input.c文件中,第383,384行左右,有如下代码:

if (skb->pkt_type == PACKET_OTHERHOST)

goto drop;

注释掉,如下:

//if (skb->pkt_type == PACKET_OTHERHOST) //noted by arvik 20160314// goto drop;

重新编译即可。

此时需要注意了,大量的非本地的数据包也会流经路由器netfilter链,我们只是对这些做一些统计,记住:统计完一定要把这些非本地的数据包丢弃掉,否则会给整个系统增加额外的负担,直接现象就是CPU占用率暴增,网络卡顿!

且你的netfilter的钩子函数一定要尽量靠前,最好在pre_routing节点,且优先级比其他钩子函数优先级都要高,这样才能尽量减少系统的的额外负担。

在做完统计后做如下检测:

if(skb->pkt_type == PACKET_OTHERHOST) //this packet is belong to other host, drop it!

return NF_DROP;

此时在路由器本地也可用netfilter钩子统计局域网其他设备互访的流量了! (^_^)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/397911.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

kali linux 升级命令_作为高级Java,你应该了解的Linux知识

原创:小姐姐味道(微信公众号ID:xjjdog),欢迎分享,转载请保留出处。作为一个javaer,我以前写过很多关于Linux的文章。但经过多年的观察,发现其实对于大部分人,有些东西压根就用不着。用的最多的&…

linux centos 光盘修复,CentOS7删除/boot/initramfsxxx.img并尝试光盘救援模式修复

CentOS7删除/boot/initramfsxxx.img并尝试光盘救援模式修复一、删除/boot/initramfs-3.10.0-957.el7.x86_64.img[rootswitch ~]# rm -f /boot/initramfs-3.10.0-957.el7.x86_64.img二、重启起不来三、插入光盘,进入修复模式(VMWare开机按esc)四、选择修复CentOS7系统…

I/O多路转接之poll,epoll

1、poll函数原型&#xff1a;#include <poll.h>int poll(struct pollfd fds[], nfds_t nfds, int timeout)&#xff1b;参数说明:fds&#xff1a;是一个struct pollfd结构类型的数组&#xff0c;用于存放需要检测其状态的Socket描述符&#xff1b;每当调用这个函数之后&a…

pn532写入手机nfc_NFC手机手环脱机模拟加密门禁卡,你get了吗?

目标&#xff1a;将门禁卡、考勤卡、会员卡、停车卡、电梯卡等等各种卡模拟进手机里&#xff0c;模拟后可用手机代替刷卡&#xff0c;无需root&#xff0c;不用电脑背景介绍&#xff1a;前言目前&#xff0c;IC卡已被广泛应用于身份识别、金融消费、安全认证等领域。大多数人每…

linux安装vim plug, vim-plug 的安装和使用

正确安装 vim-plug之前写了一篇&#x1f984; 一篇文章讲清楚如何安装vim插件&#xff0c;见各位童鞋留言说 vim-plug 更好用。果然各种插件方便管理&#xff0c;安装也很简单。下面简单说下 vim-plug 的操作基本姿势&#xff1a;安装 vim-plugvim-plug 是一个 vim 的插件管理插…

dw网页制作入学教程_简单的手机网页制作教程

很多小白会以为建站只能通过电脑&#xff0c;但实际上&#xff0c;用手机也能顺利建站&#xff0c;而且操作非常简单&#xff0c;不需要你懂技术知识哦&#xff01;下面就跟大家说说手机网页制作教程&#xff1a;首先&#xff0c;你需要选择一个比较好用的手机网页制作app。尽量…

linux 双显卡 黑屏 amd,Win10系统AMD双显卡笔记本开机出现黑屏怎么办?解决方法...

win10是一个全新的操作系统&#xff0c;所以我们在使用时很有可能会碰到一些没见过的新问题。比如&#xff0c;有用户在升级到Windows10后&#xff0c;发现AMD双显卡笔记本出现了开机黑屏的情况。具体表现为&#xff1a;Windows Logo加载之后&#xff0c;用户登陆之前会出现30s…

[BZOJ 1834] [ZJOI2010]network 网络扩容

1834: [ZJOI2010]network 网络扩容 Time Limit: 3 SecMemory Limit: 64 MBDescription 给定一张有向图&#xff0c;每条边都有一个容量C和一个扩容费用W。这里扩容费用是指将容量扩大1所需的费用。求&#xff1a; 1、 在不扩容的情况下&#xff0c;1到N的最大流&#xff1b; 2、…

fw150us的linux驱动下载,迅捷FW150US1.0/2.0无线网卡驱动

迅捷FW150US1.0/2.0无线网卡驱动官方版是迅捷推出的一款超小型150M无线USB网卡&#xff0c;安装迅捷FW150US1.0/2.0无线网卡驱动官方版&#xff0c;即可正常连接电脑使用。迅捷FW150US1.0/2.0无线网卡驱动支持自动检测功能&#xff0c;能够自动调整速率&#xff0c;无线传输速率…

20160811

一&#xff1a;边框样式 1.边框线 border-style : none | hidden | dotted | dashed | solid | double | groove | ridge | inset | outset 例&#xff1a;div { width:300px; height:100px; border-style:solid; &#xff5d; border-top-style 设置上边框线 border-bott…

vip地址能ping不通_电脑高手必备ping和netstat命令

1、Ping的基础知识ping命令相信大家已经再熟悉不过了&#xff0c;但是能把ping的功能发挥到最大的人却并不是很多&#xff0c;当然我也并不是说我可以让ping发挥最大的功能&#xff0c;我也只不过经常用ping这个工具&#xff0c;也总结了一些小经验&#xff0c;现在和大家分享一…

linux   图片

转载于:https://blog.51cto.com/wzsts/1837102

array python 交集_Python基础(二)——列表和元组

Python中最基本的数据结构是序列&#xff0c;序列中的每一个元素都有编号&#xff0c;即索引&#xff08;从左到右第一个索引为0&#xff0c;从右到左第一个索引为-1&#xff09;。python提供的序列类型在所有程序设计语言中是最丰富、最灵活&#xff0c;也是功能最强大的。pyt…

浅谈PHP+Access数据库的连接 注意要点

今天公司需要用php连接access 数据库&#xff0c;结果整了半天Access数据库 就是连接不上&#xff0c;查找 很多资料&#xff0c;以下是我的经验&#xff0c; -.- 希望能给需要连接access 数据的人带来帮助。。-.- 需要注意&#xff1a; 安装access 数据库的时候 需要安装与本…

lua 字符串分割_Lua函数式编程(中)

书接前文&#xff0c;我们继续慢慢的了解 所谓的函数式编程思想。考查下面的例子判断给定的数是否是偶数 在Lua里面这似乎是个幼儿园问题local isEven function(v) return v % 2 0 end但我们如何用函数式的思维去解决问题&#xff1f;是的&#xff0c;假设我们有了以下函数R.…

WCF技术剖析之二十七: 如何将一个服务发布成WSDL[基于HTTP-GET的实现](提供模拟程序)...

WCF技术剖析之二十七: 如何将一个服务发布成WSDL[基于HTTP-GET的实现]&#xff08;提供模拟程序&#xff09; 原文:WCF技术剖析之二十七: 如何将一个服务发布成WSDL[基于HTTP-GET的实现]&#xff08;提供模拟程序&#xff09;基于HTTP-GET的元数据发布方式与基于WS-MEX原理类似…

)标识符不能是c语言的关键字,标识符不能是C的关键字

满意答案tftgcl882014.08.07采纳率&#xff1a;58% 等级&#xff1a;9已帮助&#xff1a;3967人所谓关键字就是已被Turbo C2.0本身使用&#xff0c; 不能作其它用途使用的字。例如关键字不能用作变量名、函数名等。Turbo C2.0有以下关键字:Turbo C2.0扩展的共11个asm …

不同类的方法 事务问题_【高中地理】描述类问题的答题方法

一、描述地理位置的特征及意义位置&#xff1a;半球位置、纬度位置、海陆位置、相对位置&#xff08;邻省或邻国、地形区、地势阶梯交界处、气候区、图例中的特殊地理事物&#xff09;、板块位置、交通位置等。意义&#xff1a;①所处位置&#xff08;是否是重要分界线&#xf…

Debian 系统安装 Nagios 服务器监控端

安装apt-get updateapt-get install nagios* perlapt-get install --no-install-recommends pnp4nagiosapt-get install apache2 apache2-utils php5 php-pear 修改npcd设置# vim /etc/default/npcdRun"yes"# service npcd start 添加process_perfdata.pl执行权限ch…

spark-stream 访问 Redis

最近在spark-stream上写了一些流计算处理程序&#xff0c;程序架构如下 程序运行在Spark-stream上&#xff0c;我的目标是kafka、Redis的参数都支持在启动时指定。 在写代码时参考了这篇文章 https://www.iteblog.com/archi...&#xff0c;该文讲的比较清楚&#xff0c;但是有两…