• 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

  • 相关阅读:
    StableVideo:使用Stable Diffusion生成连续无闪烁的视频
    Qt编程,事件过滤器、绘图
    垃圾收集算法
    探索物理学的奥秘:解锁自然世界的钥匙
    SpringCloudAlibaba【四】Nacos Config 多环境切换与公共配置
    【W3Cschool之强化Python能力】
    C++模板类用作参数传递
    七、《图解HTTP》加密的协议HTTPS
    MySQL--数据库基础
    设计模式-备忘录模式
  • 原文地址:https://blog.csdn.net/lingshengxiyou/article/details/126413099