网卡RSS(receive side scaling)简介
RSS是一种网卡驱动技术,能让多核系统中跨多个处理器的网络收包处理能力高效能分配。
注意:由于同一个核的处理器超线程共享同一个执行引擎,这个效果跟有多个物理核的处理器不一样。因此,RSS不能使用超线程处理器。
为了有效的处理收包,一个miniport的驱动的接收中断服务功能调度了一个延迟过程调用(DPC)。如果没有RSS,一个典型的DPC标识了所有的收包数据都在这个DPC调用里。因此,所有收包处理关联的中断都会运行在这些中断发生的CPU上。
如有RSS功能,网卡和miniport驱动就会提供调度这些收包DPC到其他处理器上的能力。同样,RSS设计保证对于一个给定连接的处理继续停留在一个分配好的CPU上。网卡实现了一个hash散列功能和作为结果的hash值来选择一个CPU。
RSS通过减少如下开销来提高网络性能:
1、跨多个CPU分派一个网卡上的收包处理的延迟。这个也保证了不会有的CPU负载过重而另外的CPU处于空闲。
2、执行在同一个CPU上的软件算法因共享数据带来的增加自旋锁开销的可能性。
自旋锁开销的发生,比如,当一个函数执行在CPU0上,对一个数据加了自旋锁,但是另一个函数运行在CPU1上必须访问这个数据,CPU1就会一直自旋等待CPU0释放锁。
3、执行在同一个CPU上的软件算法因共享数据带来的缓存重新加载和其他资源开销增加的可能性。
这些重新加载的发生,比如,当一个函数执行并访问了CPU0上的共享数据,执行在CPU1时随之来了一个中断。
为了能在一个安全的环境中获取这些性能的提升,RSS提供如下机制:
1、分布式处理
RSS在DPC里分派给定网卡的收包处理到多个CPU上去。
2、顺序处理