如何配置Linux网络接口RSS 接收端缩放功能实现

要启用并配置linux系统的rss功能提升多核cpu处理能力,首先确认网卡支持rss,使用ethtool -x eth0查看哈希表信息;其次通过ethtool -l eth0 combined 8设置队列数量并用ethtool -l验证;接着查看/proc/interrupts获取中断号并通过修改/proc/irq//smp_affinity调整中断亲和性;最后使用top、sar等工具检查效果,并根据负载调整哈希表与绑定策略。若网卡不支持rss,可考虑使用rps替代。

如何配置Linux网络接口RSS 接收端缩放功能实现

linux系统中,启用并配置网络接口的RSS(Receive Side Scaling,接收端缩放)功能可以有效提升多核CPU处理网络数据包的能力,减少单核瓶颈。如果你发现服务器在高并发下网卡中断集中在某个CPU上,影响整体性能,开启RSS是个不错的选择。

如何配置Linux网络接口RSS 接收端缩放功能实现

下面是一些实用的配置方法和建议,适合有一定Linux基础的用户操作。


查看当前网卡是否支持RSS

首先要确认你的网卡驱动和硬件是支持RSS的。可以通过以下方式查看:

如何配置Linux网络接口RSS 接收端缩放功能实现

  • 使用 ethtool -x 命令查看当前网卡的RSS设置,例如:

    ethtool -x eth0

    如果输出类似下面的内容,说明该网卡支持RSS:

    如何配置Linux网络接口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本身不复杂,但要注意根据实际硬件和负载情况做相应调整。

© 版权声明
THE END
喜欢就支持一下吧
点赞7 分享