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

Linux RCU 机制详解

1、简介: RCU(Read-Copy Update)是数据同步一种方式,在当前Linux内核中发挥着重要作用。...2、应用场景: RCU适用于需要频繁读取数据,而相应修改数据并不多情景,例如在文件系统,经常需要查找定位目录,而对目录修改相对来说并不多,这就是RCU发挥作用最佳场景。...3、相应资料: Linux内核源码当中,关于RCU文档比较齐全,你可以在 /Documentation/RCU/ 目录下找到这些文件。 Paul E....McKenney 是内核RCU源码主要实现者,他也写了很多RCU方面的文章。他把这些文章和一些关于RCU论文链接整理到了一起。...相应链接如下: http://www2.rdrop.com/users/paulmck/RCU/ 4、实现过程: 在RCU实现过程,我们主要解决以下问题: 1,在读取过程,另外一个线程删除了一个节点

3.4K40

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

文章目录 一、RCU 机制 二、RCU 机制优势与弊端 三、RCU 机制链表应用场景 一、RCU 机制 ---- RCU , 英文全称是 " Read-Copy-Update “ , 对应中文名称是...” 读取-拷贝-更新 “ , 这是 Linux 内核 ” 同步机制 " ; Linux 内核还有其它同步机制 , 如 " 原子操作 " , " 读写信号量 " 等 " 锁机制 " ; RCU 机制..." 副本 " , 然后在副本修改 ; ③ 更新数据 ( 更新操作 ) : 只需要读取 " 共享数据 " 线程 , 离开 " 读临界区 " 后 , 指向原来 " 共享数据 " 指针 重新指向 "...副本 " , 然后再删除原来 " 共享数据 " ; 二、RCU 机制优势与弊端 ---- RCU 优势是 " 读者 " ( 读取共享数据线程 ) 不需要承担同步开销 , 同步开销指的是 : ①..." 指针 指向 拷贝 " 副本 " , 删除 原始链表数据 ; 如果 " 写线程 " 删除 " 链表 " 数据结构 , 需要 等待 所有 访问该 链表 线程 访问结束 , 即 释放该链表指针

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

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

文章目录 一、RCU 机制适用场景 二、RCU 机制特点 三、使用 RCU 机制保护链表 一、RCU 机制适用场景 ---- 在上一篇博客 【Linux 内核 内存管理】RCU 机制 ① ( RCU 机制简介...| RCU 机制优势与弊端 | RCU 机制链表应用场景 ) , 分析了 RCU 机制优势与弊端 ; 优势 : RCU 优势是 " 读者 " ( 读取共享数据线程 ) 不需要承担同步开销...动态分配 指的是 使用 malloc , calloc 等内存申请函数 , 申请数据结构 , 不是栈内存数据结构 ; RCU 机制保护 " 临界区 " ( 函数代码块 ) , 不能执行耗时操作...) 性能要求很高 ; 三、使用 RCU 机制保护链表 ---- RCU 机制 除了保护 普通指针 指向数据 之外 , 还可以用于 保护 " 链表 " 数据结构 ; Linux 内核 , 提供了 一系列...标准函数 , 可以 使用 " RCU 机制 " 保护 " 双链表 " ; 标准链表元素 : 使用 RCU 机制 保护 链表 , 链表 标准 元素 , 仍然可以使用 ; 标准函数 RCU 变体

87030

深入理解 Linux RCU 机制

RCU 一个典型应用场景是链表,在 Linux kernel 还专门提供了一个头文件(include/linux/rculist.h),提供了利用 RCU 机制对链表进行增删查改操作接口。...本文将通过一个例子,利用 rculist.h 提供接口对链表进行增删查改操作,来讲述 RCU 原理,以及介绍 Linux kernel 相关 API(基于 Linux v3.4.0 源码)。...增加链表项Linux kernel 利用 RCU 往链表增加项源码如下:#define list_next_rcu(list) (*((struct list_head __rcu **)(...访问链表项Linux kernel 访问 RCU 链表项常见代码模式是:rcu_read_lock();list_for_each_entry_rcu(pos, head, member) {...多个读端临界区不互斥,即多个读者可同时处于读端临界区,但一块内存数据一旦能够在读端临界区内被获取到指针引用,这块内存块数据释放必须等到读端临界区结束,等待读端临界区结束 Linux kernel

13.1K52

Linux 内核 内存管理】RCU 机制 ③ ( RCU 模式下添加链表项 list_add_rcu 函数 | RCU 模式下删除链表项 list_del_rcu 函数 )

- 在 Linux 源码 linux-5.6.18\include\linux\rculist.h 头文件定义就是 RCU 链表操作 , 其中定义 static inline void list_add_rcu...(struct list_head *new, struct list_head *head) 函数 , 就是 向 链表 添加元素 函数 ; list_add_rcu 函数 , 主要是调用了 _..._list_add_rcu 函数 , 在 __list_add_rcu 函数 , 将新添加 链表项 添加到了 struct list_head *prev 和 struct list_head *next...二、RCU 模式下删除链表项 list_del_rcu 函数 ---- 在 Linux 源码 linux-5.6.18\include\linux\rculist.h 头文件定义就是 RCU 链表操作..., 其中定义 static inline void list_del_rcu(struct list_head *entry) 函数 , 就是 从 链表 删除元素 函数 ; list_del_rcu

73730

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

机制 , 会 根据 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 层次架构每层最多叶子数...CONFIG_RCU_FANOUT 宏 , 表示 每个层次 支持最多叶子个数 ; #ifdef CONFIG_RCU_FANOUT #define RCU_FANOUT CONFIG_RCU_FANOUT

72910

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

所以,Linux内核引入了读-拷贝-更新技术(英文是Read-copy update,简称RCU),它是另外一种同步技术,主要用来保护被多个CPU读取数据结构。...而对于多个写操作来说,需要使用lock保护避免多个CPU并发访问。所以,其使用场合也是比较严格,多个写操作锁开销不能大于读操作采用无锁算法省下开销)。...call_rcu()函数把回调函数地址和其参数存储在rcu_head描述符,然后将这个描述符插入到每个CPU回调函数列表(这儿又体现了per-CPU变量重要性)。...当所有的CPU处于空闲状态时候,一个特殊tasklet就会执行所有的回调函数,这个tasklet描述符存储在每个CPUrcu_tasklet变量。...4 使用场合 RCU是从Linux2.6版本引入,主要使用在网络层和虚拟文件系统层。

1.6K10

Linux 历史

Linux 诞生 在 1991 年,来自芬兰 Helsinki 大学学生 Linus Torvalds 认为市场上应该有一个比较统一 Unix 版本,从此他就开始为这个项目奋斗。...后来这个项目就成为了 Linux 操作系统内核。由于当时,他只是为自己 PC 编写了这套 Linux 操作系统,原因是他当时买不起当时候主流 Intel 386 CPU 计算机。...由于这个历史原因,GNU C 编译器弦子舞仍然是编译 Linux 代码主流编译器,但也使用其他编译器,例如 Intel C 编译器。...首先他给这个项目命名为 Freax ,后来又改成了 Linux 他以需要授权形式发布了 Linux 项目,仅限于商用。Linux 使用了 GNU 软件大多数工具,并受 GNU 版权保护。...Linux 现状 如今,超级计算机,智能电话,台式机,Web 应用服务器,平板电脑,笔记本电脑和家用电器(如洗衣机,DVD 播放器,路由器,调制解调器,汽车,冰箱等)都在使用 Linux 操作系统。

1.8K10

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

函数 ---- 在 Linux 源码 linux-5.6.18\include\linux\rculist.h 头文件定义就是 RCU 链表操作 , 其中定义 static inline void...list_replace_rcu(struct list_head *old, struct list_head *new) 函数 , 就是 更新 链表元素 函数 ; list_replace_rcu...函数 , 更新链表元素核心操作就是将 被更新 链表元素 , 前后指针指向新元素即可 ; new->next = old->next; new->prev = old->prev; rcu_assign_pointer...linux\rculist.h#198 二、链表操作时使用 smp_wmb() 函数保证代码执行顺序 ---- 编译器 和 CPU 优化 代码时 , 有时会将 代码执行顺序改变 , 在链表操作时 , 代码执行顺序必须得到保证..., 否则会得到不可预知结果 ; 使用 smp_wmb() 函数 , 可以保证该函数 前两行 代码 执行完毕后 , 再执行后两行代码 ;

73320

Linux起源和发展历史

Linux操作系统历史可以追溯到上个世纪80年代末和90年代初Unix操作系统和自由软件运动。 Unix操作系统 Unix是由AT&T贝尔实验室开发一种多用户、多任务操作系统。...Unix初衷是为了满足贝尔实验室开发新型计算机需求,但是随着时间推移,Unix逐渐成为了主流操作系统之一。 在Unix系统,所有操作都是通过命令行界面完成。...自由改进软件自由。 自由软件概念最早是由斯托曼在1983年提出,他在GNU计划开发了一系列自由软件,其中包括GNU操作系统。...随着时间推移,Linux逐渐成为了一个完整操作系统,并在全球范围内得到了广泛应用。 Linux发展历程 Linux在发布后不久就开始迅速发展。...随着时间推移Linux社区不断壮大,越来越多的人加入了Linux开发行列。1994年,GNU计划创始人理查德·斯托曼加入了Linux开发,为Linux社区发展做出了重要贡献。

1.5K00

Linux_历史命令

Linux会保存用户历史指令 历史指令保存在用户目录下.bash_history文件(历史记录文件),并且每条指令都用时间戳形式记录了执行时刻 当用户通过shell进入Linux系统时,Linux...系统会先将.bash_history保存之前历史指令读取到历史记录缓存区,在用户正常退出shell之前,执行所有指令也会先记录在缓存区,当用户正常退出shell(exit或者control...+d)时,shell进程会自动将历史记录缓存区所有历史记录写入到.bash_history 查看历史缓冲区 history #查看历史记录缓存区中保存历史指令 从最开始到现在为止 通过键盘上下键快捷查看历史缓冲区...如果想主动保存缓冲区历史记录,执行 -w 选项即可 清除历史缓冲区 history -c #清除历史缓冲区 历史缓冲区写入.bash_history其实就是用新内容覆盖掉原有内容,所以清除历史缓冲区就是清除本次登录用户时所有操作记录... #重复执行缓冲区第n条历史指令 !- #重复执行缓冲区倒数第n行历史指令 !!

1.6K20

Linux-历史命令

1.history命令 命令可以查看执行过历史命令。...个指令 -c:将目前shell所有history指令全部消除 -a:将目前新增history指令加入hisfiles,如果没有加histfiles,默认写入~/.bash_history -r:...将histfile内容读取到当前shellhistory缓存 -w:将目前history缓存内容写入到histfiles 2.系统历史指令 正常情况下,Linux历史指令读取和存储过程如下...: 以bash登录Linux后,系统从HOME目录~/.bash_history文件读取历史指令 .bash_history存放指令数由HISTFILESIZE变量设定 当前shell历史指令会在注销时候写入...历史指令使用(重要) 历史指令可以结合以下指令配合: !number:执行第number个指令 !command:由最近指令向前搜寻指令串开头为command指令,并执行 !!

4.1K20

快速学习Linux-Linux历史

本文链接:https://blog.csdn.net/weixin_42528266/article/details/103046210 Linux历史 内核:只提供操作系统基本功能和特性,如内存管理...Ubuntu 国内乃至全球热门Linux发行版。也是各种推荐入门Linux爱好者安装一个Linux发行版。...,其特点如下: 1.YUM包管理(新包管理方式正在研发) 2.新技术吸纳较快,所以喜欢尝试新技术可以选择它 3.官网提供多种桌面环境镜像,可以满足不同桌面喜好用户(默认是Gnome) 4.由红帽赞助...Linux应用领域 网站服务器信息查询: www.netcraft.com 1.基于Linux企业服务器 2.嵌入式应用 Linux与Windows区别 1.Linux严格区分大小写 2.Linux...",".php" 脚本文件:"*.sh" 配置文件:"*.conf" 4.Windows下程序不能直接在Linux安装和运行 字符界面的优势 优势一:字符界面占用系统资源更少.

1.7K10

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

导语: 想要制造出质量可靠桥梁,就必须真正懂得力学原理。对于想要理解RCU软件工程师来说,也需要具备一定硬件基础。...该书作者Paul E.McKeney是IBM Linux中心领导者,Linux RCU Maintainer。...《深入理解RCU》系列文章整理了Paul E.McKeney相关著作,希望能帮助读者更深刻理解Linux内核中非常难于理解模块----RCU。...但是这仅仅是理论研究,实际工程还未应用。 二、原子操作有多慢? 这里原子操作,是特指Linux内核,类似于atomic_long_add_return这样API。...不幸是,是时候告别这种想法了。并行计算就是这么神奇和反直觉。如果不能理解这一点,就没办法真正理解RCU。 要明白这一点,考虑下面的代码片段。它被几个CPU并行执行。

4.4K31

Linux历史命令记录与隐藏

linux历史命令通常有两大用处,一个是快速复用,另外是审计,快速复用在之前文章linux命令行技巧中提过,有兴趣可以去看看,今天主要说审计部分,分两部分:记录历史命令和隐藏命令行历史,分别针对运维防护及入侵渗透...,但是这个方式前提是环境变量HISTCONTROL支持,在HISTCONTROL中有四种模式 export HISTCONTROL=erasedups # 清除整个命令历史重复条目 export...HISTCONTROL=ignoredups # 忽略记录命令历史连续重复命令 export HISTCONTROL=ignorespace # 忽略记录空格开始命令 export HISTCONTROL...然后再通过set -o history方式,开启history,这种方式好处在于,你不必全部清除所有历史命令,这样在渗透过程可以灵活屏蔽不想被记录命令,而不会被审计人员发现 history命令管理...或者通过上下键翻找历史命令,通过Ctrl+U来清除当前行记录 ? 不过这种方式会留个小马脚 ok,以上就是今天要介绍linux下命令历史记录保存及隐藏方式

6.1K30

Linux介绍以及其发展历史

前言 本文介绍了为什么要发明计算机、为什么要有操作系统以及Linux发展历史等概念。 一、技术是推动社会发展基本动力 1.人为什么能成为万物之长呢?...三、Linux发展基本脉络 第一代Linux开源后,全世界顶尖黑客和工程师参与该项目(他们不缺钱,只为了改变世界),此后Linux越来越大 1.开源和闭源哪个更好?...(修订次数,偶数次:稳定版本,奇数次:测试版本) 商业化发行版本:Ubuntu,CentOS/redhat、kali、红旗等版本 要注意,Linux是开源,但不代表用Linux做出来产品是免费...操作系统是一款管理软件 总结 以上就是今天要讲内容,本文介绍了Linux历史等相关概念。...本文作者目前也是正在学习Linux相关知识,如果文章内容有错误或者不严谨部分,欢迎大家在评论区指出,也欢迎大家在评论区提问、交流。

9110

linux查看历史命令history

n 条命令行表意思; -c :将目前 shell 所有 history 内容全部消除; -a :将目前新增 history 命令新增入 histfiles ,若没有加histfiles...-n 重复n个命令之前那个命令 2、按键组合 使用up和down键来上下浏览之前执行命令 键入ctr+r来在命令历史搜索命令 代码如下: [root@jb51 Desktop]# (reverse-i-search...修改历史命令保存数量 比如设置只能保存100条历史记录: [root@zcwyou ~]# vi ~/.bash_profile linux修改历史命令保存数量 修改以下两行内容: HISTSIZE...使用HISTCONTROL来清除命令历史连续重复条目 比如连续三次输入命令 ll 9....替换历史命令内容 比如,你查看了cp1.txt内容 [root@zcwyou ~]# cat cp1.txt 然后想编辑它: [root@zcwyou ~]# vi !!:$ !!

10.9K10
领券