图1.1 82575硬件逻辑图
2. 2.6.21以前网卡驱动实现
kernel从2.6.21之前不支持多队列特性,一个网卡只能申请一个中断号 , 因此同一个时刻只有一个核在处理网卡收到的包 。如图2.1,协议栈通过NAPI轮询收取各个硬件queue中的报文到图2.2的net_device数据结构中,通过QDisc队列将报文发送到网卡 。
文章插图
图2.1 2.6.21之前内核协议栈
图2.2 2.6.21之前net_device
3. 2.6.21后网卡驱动实现
2.6.21开始支持多队列特性,当网卡驱动加载时,通过获取的网卡型号,得到网卡的硬件queue的数量,并结合CPU核的数量,最终通过Sum=Min(网卡queue,CPU core)得出所要激活的网卡queue数量(Sum),并申请Sum个中断号,分配给激活的各个queue 。
如图3.1,当某个queue收到报文时,触发相应的中断,收到中断的核 , 将该任务加入到协议栈负责收包的该核的NET_RX_SOFTIRQ队列中(NET_RX_SOFTIRQ在每个核上都有一个实例),在NET_RX_SOFTIRQ中,调用NAPI的收包接口,将报文收到CPU中如图3.2的有多个netdev_queue的net_device数据结构中 。
这样,CPU的各个核可以并发的收包,就不会应为一个核不能满足需求,导致网络IO性能下降 。
文章插图
图3.1 2.6.21之后内核协议栈
【linux多网卡绑定怎么实现 Linux多队列网卡的硬件的实现详解】图3.2 2.6.21之后net_device
4.中断绑定
当CPU可以平行收包时,就会出现不同的核收取了同一个queue的报文,这就会产生报文乱序的问题,解决方法是将一个queue的中断绑定到唯一的一个核上去,从而避免了乱序问题 。同时如果网络流量大的时候,可以将软中断均匀的分散到各个核上,避免CPU成为瓶颈 。
文章插图
图4.1 /proc/interrupts
5.中断亲合纠正
一些多队列网卡驱动实现的不是太好,在初始化后会出现图4.1中同一个队列的tx、rx中断绑定到不同核上的问题,这样数据在core0与core1之间流动,导致核间数据交互加大 , cache命中率降低,降低了效率 。
图5.1 不合理中断绑定
linux network子系统的负责人David Miller提供了一个脚本,首先检索/proc/interrupts文件中的信息 , 按照图4.1中eth0-rx-0($VEC)中的VEC得出中断MASK,并将MASK
写入中断号53对应的smp_affinity中 。由于eth-rx-0与eth-tx-0的VEC相同,实现同一个queue的tx与rx中断绑定到一个核上,如图4.3所示 。
文章插图
文章插图
图4.2 set_irq_affinity
推荐阅读
- 如何让红旗Linux支持fFTP服务并允许root用户登录
- linux怎么安装mysql数据库并配置
- 打完新冠疫苗能不能摘口罩
- 哥斯拉是怎么吐出原子吐息的?
- 如何评价电视剧《琅琊榜》?你觉得哪个角色是最委屈的呢?
- 打完疫苗后多久可以洗澡
- 柳传志事件官方怎样处理 柳传志事件是怎么回事?
- 电影《哥斯拉2-怪兽之王》你觉得怎么样?
- linux查看系统版本的方法汇总数据 Linux查看系统版本的方法汇总