什么是 RSS
RSS (Receive Side Scaling) 是一种能够在多处理器系统下使接收报文在多个 CPU 之间高效分发的网卡驱动技术。
- 网卡对接收到的报文进行解析,获取 IP 地址、协议和端口五元组信息
- 网卡通过配置的 HASH 函数根据五元组信息计算出 HASH 值,也可以根据二、三或四元组进行计算。
- 取 HASH 值的低几位 (这个具体网卡可能不同) 作为 RETA (redirection table) 的索引
- 根据 RETA 中存储的值分发到对应的 CPU
下图描述了完整的处理流程:
基于 RSS 技术程序可以通过硬件在多个 CPU 之间来分发数据流,并且可以通过对 RETA 的修改来实现动态的负载均衡。
在 DPDK 中配置 RSS
DPDK 支持设置静态 hash 值和配置 RETA。 不过 DPDK 中 RSS 是基于端口的,并根据端口的接收队列进行报文分发的。 例如我们在一个端口上配置了 3 个接收队列 (0,1,2) 并开启了 RSS,那么 中就是这样的:
{0,1,2,0,1,2,0.........}
运行在不同 CPU 的应用程序就从不同的接收队列接收报文,这样就达到了报文分发的效果。
在 DPDK 中通过设置 rte_eth_conf 中的 mq_mode 字段来开启 RSS 功能, rx_mode.mq_mode = ETH_MQ_RX_RSS。
当 RSS 功能开启后,报文对应的 rte_pktmbuf 中就会存有 RSS 计算的 hash 值,可以通过 pktmbuf.hash.rss 来访问。 这个值可以直接用在后续报文处理过程中而不需要重新计算 hash 值,如快速转发,标识报文流等。
RETA 是运行时可配置的,这样应用程序就

RSS(Receive Side Scaling)是一种在多处理器系统中优化网络报文处理的技术,通过HASH函数将报文分发到不同CPU。在DPDK中,RSS根据端口接收队列进行报文分发,可通过配置RETA(Redirection Table)实现动态负载均衡。对称RSS确保同一连接的双向报文在同一CPU处理,提高性能。本文探讨了DPDK中RSS的配置和对称RSS的实现方法。

4641

被折叠的 条评论
为什么被折叠?



