多队列网卡介绍

Posted scaugsh

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了多队列网卡介绍相关的知识,希望对你有一定的参考价值。

1)   简介

多队列网卡是指一个网卡上有多个队列,内核会给每个队列注册一个中断号,具体可以在/proc/interrupts | grep {网卡} 查看,其中第一列是中断号,最后一列是网卡队列信息。CPU和中断号有亲和性,一般网卡中断和一个CPU绑定,绑定关系可以在/proc/irq/{中断号}/smp_affinity_list查看。

2)   疑惑

网卡与内存数据传输有两种方式,一种是DMA,一种是IRQ。DMA是指有个DMAC(DMA控制器)负责将网卡数据放到指定buffer上,然后CPU在空闲时去处理这部分信息。IRQ是指网卡通过中断提醒CPU可操作,然后CPU进行读写。

这里我有疑问,网上有人说网卡上的队列就是所谓的DMA的缓冲区,那么就是说IRQ和DMA是同时应用在网卡上的。但我又看到一种说法是, DMA是不需要中断的,一般是CPU有空就去处理。具体是哪种我也不清楚。

在测试时,通过查询CPU处理中断的次数,可以发现中断次数和发包数不一致,所以应该是一次中断处理了多个包。

以上是关于多队列网卡介绍的主要内容,如果未能解决你的问题,请参考以下文章

网卡多队列

虚机网卡多队列提高网络I/O带宽QoS

RPS和RFS网卡多队列性能调优实践

ethtool原理介绍和解决网卡丢包排查思路

一文解决ethtool 原理介绍和解决网卡丢包排查思路

网卡多队列