首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Linux 内核 内存管理】RCU 机制 ② ( RCU 机制适用场景 | RCU 机制特点 | 使用 RCU 机制保护链表 )

文章目录 一、RCU 机制适用场景 二、RCU 机制特点 三、使用 RCU 机制保护链表 一、RCU 机制适用场景 ---- 在上一篇博客 【Linux 内核 内存管理】RCU 机制 ① ( RCU 机制简介...) 需要 承担很大的同步开销 , 其需要 ① 延迟对象释放 , ② 读取 并 复制 共享数据 , ③ 必须使用 互斥锁 机制 ; ④ 使用复杂 , 比其它互斥锁要复杂 ; RCU 机制 适用于 " 读者...动态分配 指的是 使用 malloc , calloc 等内存申请函数 , 申请的数据结构 , 不是栈内存数据结构 ; RCU 机制保护的 " 临界区 " ( 函数代码块 ) 中 , 不能执行耗时操作...) 性能要求很高 ; 三、使用 RCU 机制保护链表 ---- RCU 机制 除了保护 普通指针 指向的数据 之外 , 还可以用于 保护 " 链表 " 数据结构 ; Linux 内核中 , 提供了 一系列的...标准函数 , 可以 使用 " RCU 机制 " 保护 " 双链表 " ; 标准链表元素 : 使用 RCU 机制 保护 的 链表 , 链表中的 标准 元素 , 仍然可以使用 ; 标准函数 RCU 变体

85930

Linux RCU 机制详解

1、简介: RCU(Read-Copy Update)是数据同步的一种方式,在当前的Linux内核中发挥着重要的作用。...RCU主要针对的数据对象是链表,目的是提高遍历读取数据的效率,为了达到目的使用RCU机制读取数据的时候不对链表进行耗时的加锁操作。...3、相应资料: Linux内核源码当中,关于RCU的文档比较齐全,你可以在 /Documentation/RCU/ 目录下找到这些文件。 Paul E....McKenney 是内核中RCU源码的主要实现者,他也写了很多RCU方面的文章。他把这些文章和一些关于RCU的论文的链接整理到了一起。...4.2 订阅——发布机制: 当前使用的编译器大多会对代码做一定程度的优化,CPU也会对执行指令做一些优化调整,目的是提高代码的执行效率,但这样的优化,有时候会带来不期望的结果。

3.4K40
您找到你想要的搜索结果了吗?
是的
没有找到

Linux 内核 内存管理】RCU 机制 ① ( RCU 机制简介 | RCU 机制的优势与弊端 | RCU 机制的链表应用场景 )

文章目录 一、RCU 机制 二、RCU 机制的优势与弊端 三、RCU 机制的链表应用场景 一、RCU 机制 ---- RCU , 英文全称是 " Read-Copy-Update “ , 对应的中文名称是...” 读取-拷贝-更新 “ , 这是 Linux 内核中的 ” 同步机制 " ; Linux 内核中还有其它同步机制 , 如 " 原子操作 " , " 读写信号量 " 等 " 锁机制 " ; RCU 机制...机制的优势与弊端 ---- RCU 的优势是 " 读者 " ( 读取共享数据的线程 ) 不需要承担同步开销 , 同步开销指的是 : ① 获取 " 锁 " , ② 执行 " 原子指令 " , ③ 执行..." 内存屏障 " ; 与此相对的 RCU 机制也有一定弊端 , " 写者 " ( 修改共享数据的线程 ) 需要 承担很大的同步开销 , 其需要 ① 延迟对象释放 , ② 读取 并 复制 共享数据 , ③...必须使用 互斥锁 机制 ; 三、RCU 机制的链表应用场景 ---- RCU 机制 可以极大地 提高 " 链表 " 数据结构的 读取效率 , 多个线程 同时读取 链表 时 , 使用 rcu_read_lock

1.7K20

Linux 内核 内存管理】RCU 机制 ④ ( RCU 模式下更新链表项 list_replace_rcu 函数 | 链表操作时使用 smp_wmb() 函数保证代码执行顺序 )

文章目录 一、RCU 模式下更新链表项 list_replace_rcu 函数 二、链表操作时使用 smp_wmb() 函数保证代码执行顺序 一、RCU 模式下更新链表项 list_replace_rcu...函数 ---- 在 Linux 源码 linux-5.6.18\include\linux\rculist.h 头文件中定义的就是 RCU 链表的操作 , 其中定义的 static inline void...(new->prev), new); new->next->prev = new; old->prev = LIST_POISON2; } 源码路径 : linux-5.6.18\include\...linux\rculist.h#198 二、链表操作时使用 smp_wmb() 函数保证代码执行顺序 ---- 编译器 和 CPU 优化 代码时 , 有时会将 代码执行顺序改变 , 在链表操作时 , 代码的执行顺序必须得到保证..., 否则会得到不可预知的结果 ; 使用 smp_wmb() 函数 , 可以保证该函数 前两行 的代码 执行完毕后 , 再执行后两行的代码 ;

72520

Linux 内核 内存管理】RCU 机制 ⑤ ( RCU 层次架构概念 | RCU 层次架构源码解析 | RCU 层次架构每层最多叶子数 | RCU 层次架构每个叶子 CPU 数量 )

文章目录 一、RCU 层次架构概念及源码 二、RCU 层次架构源码解析 1、RCU 层次架构每层最多叶子数 2、RCU 层次架构每个叶子 CPU 数量 一、RCU 层次架构概念及源码 ---- RCU...机制 中 , 会 根据 CPU 数量 , 按照 " 树形结构 “ 组成 RCU 层次架构 , 称为 ” RCU Hierarchy " ; 在 Linux 源码 linux-5.6.18\include...\linux\rcu_node_tree.h 头文件中定义了 RCU 层次架构 , RCU 层次架构 源码 : /* * Define shape of hierarchy based on NR_CPUS..._4 (RCU_FANOUT_3 * RCU_FANOUT) 源码路径 : linux-5.6.18\include\linux\rcu_node_tree.h#31 二、RCU 层次架构源码解析...---- " RCU 层次架构 “ 是 根据 ” CPU 数量 " 确定的 , 在 Linux 内核源码中 , 通过各种 " 宏定义 “ 构建 ” RCU 层次架构 " , 1、RCU 层次架构每层最多叶子数

72210

深入理解 LinuxRCU 机制

RCU(Read-Copy Update),是 Linux 中比较重要的一种同步机制。...RCU 的一个典型的应用场景是链表,在 Linux kernel 中还专门提供了一个头文件(include/linux/rculist.h),提供了利用 RCU 机制对链表进行增删查改操作的接口。...(list_next_rcu(prev), new); next->prev = new;}list_next_rcu() 函数中的 rcu 是一个供代码分析工具 Sparse 使用的编译选项...,规定有 rcu 标签的指针不能直接使用,而需要使用 rcu_dereference() 返回一个受 RCU 保护的指针才能使用。...因此上一节 “增加链表项” 中提到的 “__rcu” 编译选项强制检查是否使用 rcu_dereference() 访问受 RCU 保护的数据,实际上是为了让代码拥有更好的可移植性。

13K52

Linux内核32-读-拷贝-更新(RCU

所以,Linux内核引入了读-拷贝-更新技术(英文是Read-copy update,简称RCU),它是另外一种同步技术,主要用来保护被多个CPU读取的数据结构。...RCU允许多个读操作和多个写操作并发执行。更重要的是,RCU是一种免锁算法,也就是说,它没有使用共享的锁或计数器保护数据结构(但是,这儿还是主要指的读操作是无锁算法。...2 RCU实现 既然RCU没有使用共享数据结构,那么它是如何神奇地实现同步技术的呢?其核心思想就是限制RCU使用范围: 只有动态分配的、通过指针进行访问的数据结构。...尤其是当使用了自旋锁保护RCU禁止多个写操作的并发访问的时候。 (3)调用synchronize_rcu,等待所有的读操作都离开临界代码段,完成同步。...4 使用场合 RCU是从Linux2.6版本引入的,主要使用在网络层和虚拟文件系统层。

1.6K10

helm——工具使用举例

一、helm支持的四种安装方法 安装仓库中的chart包,命令举例:helm install stable/xxx; 通过tar包安装,命令举例:helm install xxx-1.tgz(不推荐使用...); 通过chart本地目录安装,命令举例:helm install xxx/xxx(一般是使用helm fetch stable/xxxxx 下载相应的模板,然后使用tar zxf 解压,修改解压后的目录中的...valumes.yaml文件中的值,就是自定义服务了,这种方式比较常用); 通过URL安装,不太常用,命令举例:helm install https://xxxx/charts/xxx-1.gz 。...二、自定义Chart包举例 //创建testchart包 [root@docker-k8s01 ~]# helm create testchart //可以看到生成的目录下各种模板都有了,根据业务需求进行更改即可...表示指定其名称 [root@docker-k8s01 ~]# helm install stable/mysql --set mysqlRootPassword=123.com -n test-mysql //使用

81641

谢宝友: 深入理解 Linux RCU 之从硬件说起

对于想要理解RCU的软件工程师来说,也需要具备一定的硬件基础。 作者简介:谢宝友,在编程一线工作已经有20年时间,其中接近10年时间工作于Linux操作系统。...该书作者Paul E.McKeney是IBM Linux中心领导者,Linux RCU Maintainer。...《深入理解RCU》系列文章整理了Paul E.McKeney的相关著作,希望能帮助读者更深刻的理解Linux内核中非常难于理解的模块----RCU。...当然,这个硬件计数值主要是在power架构上有效,笔者在powerpce500架构上经常使用它。第3-8行的循环,记录变量在当前CPU上保持的时间长度。...因为这通常是由于几个CPU使用缓存通信造成的(例如,一个用于互斥算法的锁使用这个数据项在CPU之间进行通信)。 很明显,所有CPU必须小心的维护数据的一致性视图。

4.4K31

消息队列的使用(kafka举例

在Java的线程池中我们就会使用一个队列(BlockQueen等)来存储提交的任务; 在操作系统中中断的下半部分也会使用工作队列来实现延后执行 还有RPC框架,也会从网络上姐收到请求写到消息队列里,在启动若干个工作线程来进行消费...总之不管是在我们的生活中还是在系统设计中使用消息队列的设计模式和消息队列组件实在是太多了。 为什么有这么多地方都用消息队列呢?...(在业务需求允许的演出时间内) 扩展性:当使用的消息队列处在消息对立的数据可以被任何地方消费。可以做任何的数据处理操作等。...异步通信:很多时候我们不想同步处理一些数据,或者是业务流程比较长,将中间的一些环节异步处理,那么我们就可以使用消息队列。...还有就是在消费端进行幂等设计 可以在通用层进行幂等设计,一般在使用中间件的时候,会对其封装一层。为方便业务逻辑层的使用

77210

谢宝友:深入理解 Linux RCU 从硬件说起之内存屏障

这不是一篇单独的文章,这是《谢宝友:深入理解Linux RCU》系列的第2篇,前序文章:《谢宝友:深入理解 Linux RCU 从硬件说起之内存屏障》 作者简介:谢宝友,在编程一线工作已经有20年时间...,其中接近10年时间工作于Linux操作系统。...该书作者Paul E.McKeney是IBM Linux中心领导者,Linux RCU Maintainer。...《深入理解RCU》系列文章整理了Paul E.McKeney的相关著作,希望能帮助读者更深刻的理解Linux内核中非常难于理解的模块----RCU。...4、内存屏障的传递性,这是Linux系统中比较微妙而难于理解的概念。 5、单核架构中的屏障,是为了解决什么问题?怎么使用? 6、屏障在内核同步原语中的使用,满足了什么样的同步原语语义?

6.8K44
领券