要启用并配置linux系统的rss功能提升多核cpu处理能力,首先确认网卡支持rss,使用ethtool -x eth0查看哈希表信息;其次通过ethtool -l eth0 combined 8设置队列数量并用ethtool -l验证;接着查看/proc/interrupts获取中断号并通过修改/proc/irq/
linux系统中,启用并配置网络接口的RSS(Receive Side Scaling,接收端缩放)功能可以有效提升多核CPU处理网络数据包的能力,减少单核瓶颈。如果你发现服务器在高并发下网卡中断集中在某个CPU上,影响整体性能,开启RSS是个不错的选择。
下面是一些实用的配置方法和建议,适合有一定Linux基础的用户操作。
查看当前网卡是否支持RSS
首先要确认你的网卡驱动和硬件是支持RSS的。可以通过以下方式查看:
-
使用 ethtool -x
命令查看当前网卡的RSS设置,例如: ethtool -x eth0
如果输出类似下面的内容,说明该网卡支持RSS:
RX flow hash indirection table for eth0: 00: 0 1 2 3 4 5 6 7 ...
-
另外也可以通过查看 /proc/interrupts 文件,看看网卡中断是否分布在多个CPU上。
小提示:有些老旧的网卡或者虚拟化环境中的虚拟网卡可能不支持完整的RSS功能,这时候需要考虑使用RPS(软件层面的接收端处理调度)作为替代方案。
启用并配置RSS队列数量
很多网卡默认只启用了1个RSS队列,也就是所有流量都由一个CPU处理。你可以手动增加队列数来实现负载均衡。
-
使用 ethtool 设置RSS队列数量,比如将队列数设为8:
ethtool -L eth0 combined 8
-
确认设置是否生效:
ethtool -l eth0
注意:不是所有网卡都允许任意调整队列数量,最大值取决于硬件型号。如果命令执行失败,可以尝试较小的数值。
调整中断亲和性,优化CPU利用率
即使开启了多个RSS队列,也不代表中断就一定均匀分配到了各个CPU上。你需要手动调整中断亲和性(IRQ affinity),让不同队列的中断分散到不同的CPU核心上。
-
查看网卡对应的中断号:
grep eth0 /proc/interrupts
-
编辑 /proc/irq/
/smp_affinity 文件,设置中断绑定的CPU掩码。例如将中断绑定到前4个CPU: echo 0f > /proc/irq/123/smp_affinity
这里的“0f”是十六进制表示法,对应二进制的00001111,也就是CPU0~3。
提示:可以用脚本批量设置多个中断的affinity,或者使用 irqbalance 工具自动平衡中断分布。
检查效果与调优建议
完成配置后,观察系统的网络性能变化。可以通过以下方式验证:
- 使用 top 或 htop 观察CPU使用率是否更均匀。
- 使用 sar -n DEV 1 监控网卡流量。
- 再次运行 ethtool -x eth0 查看哈希表是否已更新。
如果你发现某些CPU仍然负载较高,可以尝试:
- 调整RSS哈希表内容(通过 ethtool -X 修改)
- 更改中断绑定策略,避开负责其他任务的CPU
- 结合RFS或XPS进一步优化数据包处理路径
基本上就这些了。配置RSS本身不复杂,但要注意根据实际硬件和负载情况做相应调整。