当前位置: 首页 > news >正文

DPDK中的无锁共享数据结构

目录

  • 背景
  • 解决方法
    • 共享内存
    • 无锁操作
      • 新/老共享数据结构
      • rte_ring
      • refcnt
      • 延迟释放
        • 方法1:读的线程来释放
        • 方法2:释放线程等到读线程轮询一轮
  • 参考

背景

dpvs多线程,如何做到节约内存、高性能之间的均衡。

解决方法

共享内存

多线程共享内存,意味着节约内存。

无锁操作

无锁操作,意味着高性能。
如果是配置 per-core,也可以做到高性能,不需要加锁,但是会浪费内存。
多线程共享内存,如何做到无锁呢?

新/老共享数据结构

从来都不是对原有共享数据结构进行更新;
每次更新,都是控制线程新建立一个共享数据结构,在转发线程引用新的数据结构之前,转发线程中继续使用原有老的共享数据结构。

rte_ring

通过 rte_ring 的方式,将控制线程中创建的数据结构的指针,传递给转发线程。

refcnt

原子变量的refcnt。
每次被转发线程引用数据结构,则refcnt++;
每次被转发线程解除引用老的数据结构时:先引用新的结构,然后解除对老的结构的引用【refcnt–】;
refcnt为0时,考虑将共享数据结构释放
【此时应该可以立刻释放,也可以延迟释放】

延迟释放

如果是延迟释放,主要是考虑的释放的时候,是否有其他线程在读取。

方法1:读的线程来释放

思想:
释放旧数据的时候可能有线程在读,某线程读完了旧数据之后,再在这个线程中释放旧的数据,做到了读和释放都是一个线程。【该线程读完旧的数据之后,往后的轮询获取的都是新的数据,不会再读取就的数据了,然后就可以释放旧的数据了】

具体:
可以在每个转发线程中,构建一个释放节点的链表,链表中每个节点包含要释放的数据,释放函数等,转发线程CAS的方式更新链表。
在控制线程中,CAS的方式摘取每个转发线程的释放链表,统一进行释放。

方法2:释放线程等到读线程轮询一轮

释放旧的数据的线程,在释放旧的数据的时候,不确定是否有其他的线程正在读取这个数据。可以在释放之前,等待其他线程轮询一轮之后,后续其他线程再次读取的就是新的数据,释放线程就可以释放旧的数据了。

参考

rust中的 无锁数据结构内存管理:
https://rustmagazine.github.io/rust_magazine_2021/chapter_6/rust-lockfree.html#%E6%97%A0%E9%94%81%E6%95%B0%E6%8D%AE%E7%BB%93%E6%9E%84%E5%86%85%E5%AD%98%E7%AE%A1%E7%90%86
http://www.lryc.cn/news/24972.html

相关文章:

  • 【使用两个栈实现队列】
  • web,h5海康视频接入监控视频流记录一
  • 做毕业设计,前端部分你需要掌握的6个核心技能
  • Read book Netty in action(Chapter VIII)--EventLoop and thread model
  • 番外11:使用ADS对射频功率放大器进行非线性测试3(使用带宽5MHz的WCDMA信号进行ACLR测试)
  • Linux libpqxx 库安装及使用
  • 如何使用COM-Hunter检测持久化COM劫持漏洞
  • Cartesi 举办的2023 黑客马拉松
  • 架构篇--代码质量手册
  • 那些年用过的IDEA插件
  • python+requests实现接口自动化测试
  • rtthread 线程
  • 伯恩光学再成被执行人:多次因劳动纠纷被起诉,曾冲刺港交所上市
  • mysql基础操作2
  • 指针的进阶【下篇】
  • 不同序列模型的输入和输出总结
  • 基于神经网络补偿的主动悬架自适应控制
  • 什么是链表,如何实现?(单链表篇)
  • 探针台简介
  • ABAP 辨析 标准表|排序表|哈希表
  • MIGO 物料过账 创建物料凭证 BAPI_GOODSMVT_CREATE
  • 项目经理处理团队冲突 5大注意事项
  • Linux(Centos)安装TDengine
  • 大数据处理技术导论(6) | Datawhale组队学习46期
  • Java——异常
  • Netty之io.netty.util.concurrent.Promise与io.netty.util.concurrent.Future初解
  • 【正点原子FPGA连载】第二十一章AXI DMA环路测试 摘自【正点原子】DFZU2EG_4EV MPSoC之嵌入式Vitis开发指南
  • 手把手搭建springboot项目06-springboot整合RabbitMQ及其原理和应用场景
  • 如何根据IP地址判断是IPv4还是IPv6
  • 山地车和公路车怎么选