• DPDK网卡RSS(receive side scaling)简介


    网卡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

  • 相关阅读:
    两段锁协议
    java计算机毕业设计ssm养老院敬老院系统 elementui
    Ai语音机器人系统语音识别达到了什么水准
    HTTPS协议详解
    一辆公交车的故事
    a16z公布AI产品流量排名,ChatGPT占据榜首
    HJ65 查找两个字符串a,b中的最长公共子串
    思维训练1
    SpringMVC(八):SSM整合
    可执行文件以管理员身份运行
  • 原文地址:https://blog.csdn.net/lingshengxiyou/article/details/126413099