linux网络接口的rss散列功能通过将数据包分发到不同cpu核心,提升多核性能。1. 确认网卡和驱动支持rss,使用ethtool命令查看接口信息及哈希配置;2. 查看并设置rss哈希类型,如tcp4、udp4等,以实现基于不同字段的负载均衡;3. 高级网卡允许设置自定义哈希密钥,以控制流分布,需按正确格式设置十六进制密钥;4. 可选调整队列映射表,手动指定哈希值与队列索引的对应关系,实现更精细的流量控制。

Linux网络接口的RSS(Receive Side Scaling)散列功能可以有效提升多队列网卡在多核CPU下的性能。通过合理配置RSS哈希算法,可以将不同连接的数据包分发到不同的CPU核心上处理,从而提高吞吐量和降低延迟。如果你有特定的业务需求,比如希望根据源IP或目标端口做更精细的负载均衡,那么自定义哈希算法就变得非常关键了。

1. 确认硬件支持
不是所有网卡都支持RSS,也不是所有驱动都允许你修改哈希算法。第一步是确认你的网卡和驱动是否具备这个能力:
- 使用
ethtool -i查看驱动信息 - 使用
ethtool --show-rxfh-indir-size查看支持的队列数 - 使用
ethtool --show-rxfh查看当前哈希配置
如果输出中显示支持 RSS 或 RFS(Receive Flow Steering),并且可以查看或设置哈希键和散列函数,那就可以继续下一步。

2. 理解RSS哈希类型
Linux下常见的RSS哈希类型包括基于TCP/UDP的四元组(源IP、目的IP、源端口、目的端口)、仅IP地址、或仅端口等。你可以使用如下命令查看当前接口支持的哈希类型:
ethtool --show-rxfh
典型的哈希类型选项包括:

-
none:不启用RSS -
tcp4:IPv4 TCP流量 -
udp4:IPv4 UDP流量 -
ah4/esp4:IPsec协议 -
sctp4:SCTP协议 -
tcp6/udp6:IPv6版本
你可以通过下面命令设置新的哈希规则,例如只对TCP流量做四元组哈希:
ethtool --set-rxfhtcp4
如果你想同时支持多种协议组合,可以写成:
ethtool --set-rxfhtcp4 udp4 tcp6
3. 自定义哈希算法与密钥
有些高级网卡允许你自定义哈希函数使用的密钥(也叫“RSS key”),甚至部分厂商提供定制化的哈希逻辑。这通常用于确保不同主机之间哈希分布一致,或者避免某些特定流被分配到同一个队列。
要查看当前的哈希密钥:
ethtool --get-rxfh
要设置新的密钥(以十六进制形式):
ethtool --set-rxfhindir ... key
注意:密钥长度取决于网卡型号,一般为40字节或更长,格式错误可能导致设置失败。
4. 调整队列映射(可选)
除了哈希算法,你还可以手动调整每个哈希值对应的队列索引(indirection table)。这对于实现更复杂的负载均衡策略很有用,比如让某些CPU专门处理特定类型的流量。
查看当前映射表:
ethtool --get-rxfh
设置新的映射(需要构造一个对应队列数量的索引数组):
ethtool --set-rxfhindir 0 1 2 3 0 1 2 3 ...
这个操作相对复杂,建议结合脚本或工具来生成合理的映射关系。
基本上就这些。虽然配置过程看起来不复杂,但实际应用时容易忽略细节,比如驱动兼容性、队列数量限制、以及密钥格式等问题。只要按步骤操作,并参考设备手册,应该能顺利完成自定义哈希配置。










