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