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

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

文章目录 一、RCU 机制适用场景 二、RCU 机制特点 三、使用 RCU 机制保护链表 一、RCU 机制适用场景 ---- 在上一篇博客 【Linux 内核 内存管理】RCU 机制 ① ( RCU 机制简介...| RCU 机制的优势与弊端 | RCU 机制的链表应用场景 ) 中 , 分析了 RCU 机制的优势与弊端 ; 优势 : RCU 的优势是 " 读者 " ( 读取共享数据的线程 ) 不需要承担同步开销..." ( 读取共享数据的线程 ) 性能要求高的场景 ; 二、RCU 机制特点 ---- RCU 机制 只能 保护 " 动态分配 “ 的 ” 共享数据结构 " , 该 共享数据 必须 通过指针访问 , 这里的...) 性能要求很高 ; 三、使用 RCU 机制保护链表 ---- RCU 机制 除了保护 普通指针 指向的数据 之外 , 还可以用于 保护 " 链表 " 数据结构 ; Linux 内核中 , 提供了 一系列的...标准函数 , 可以 使用 " RCU 机制 " 保护 " 双链表 " ; 标准链表元素 : 使用 RCU 机制 保护 的 链表 , 链表中的 标准 元素 , 仍然可以使用 ; 标准函数 RCU 变体

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

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

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

    1.9K20

    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 层次架构每层最多叶子数

    80010

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

    所以,Linux内核引入了读-拷贝-更新技术(英文是Read-copy update,简称RCU),它是另外一种同步技术,主要用来保护被多个CPU读取的数据结构。...2 RCU实现 既然RCU没有使用共享数据结构,那么它是如何神奇地实现同步技术的呢?其核心思想就是限制RCU的使用范围: 只有动态分配的、通过指针进行访问的数据结构。...进入RCU保护的临界代码段的内核控制路径不能休眠。 3 基本操作 对于reader,RCU的基本操作为: (1)调用rcu_read_lock(),进入RCU保护的临界代码段。...对于writer,RCU的基本操作为: (1)拷贝一份旧数据到新数据,修改新数据。 (2)调用rcu_assign_pointer(),将RCU保护的指针修改为新数据的指针。...4 使用场合 RCU是从Linux2.6版本引入的,主要使用在网络层和虚拟文件系统层。

    1.7K10

    深入理解 LinuxRCU 机制

    RCU(Read-Copy Update),是 Linux 中比较重要的一种同步机制。...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) {

    14K52

    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...(list_next_rcu(new->prev), new); new->next->prev = new; old->prev = LIST_POISON2; list_replace_rcu...(new->prev), new); new->next->prev = new; old->prev = LIST_POISON2; } 源码路径 : linux-5.6.18\include\...linux\rculist.h#198 二、链表操作时使用 smp_wmb() 函数保证代码执行顺序 ---- 编译器 和 CPU 优化 代码时 , 有时会将 代码执行顺序改变 , 在链表操作时 , 代码的执行顺序必须得到保证

    77520

    谢宝友:深入理解RCU之六:分级RCU基础

    1、准备工作 本文基于linux 2.6.32-rc7版本的源码, 因此请准备一份linux2.6.32-rc7代码。建议用如下两种方法获取源代码: 1、直接在linux.org上面下载源码包。...2、使用git从linux-next拉取最新代码,然后使用git checkout -b linux-2.6.32-rc7 v2.6.32-rc7检出2.6.32-rc7版本的源码。...这削弱了LINUX节能的能力。 2.3. RCU 迫切要解决的问题 实时RCU迫切要解决的问题列表如下: 1. 延迟销毁。...如上图,每一个每CPU rcu_dynticks结构被“rcu”和“rcu_bh”实现所共享。 2.6. 状态机 从十分高层的视角来看,Linux内核RCU 实现可以被认为是一个高级状态机,如上图。...结论 这个分级RCU实现减少了锁竞争,避免了不必要的唤醒dyntick-idle睡眠状态的CPU,因此有助于调试Linux CPU热插拨代码。

    86410

    谢宝友: 深入理解RCU之七:分级RCU实现

    rcurcu_bh共享这个值。 1.2. 分级RCU实现中的节点 rcu_node是被放到 rcu_state结构内的。...RCU全局状态 rcu_state 结构包含每一个RCU实例(rcurcu_bh)的全局状态。...在某些LINUX版本的经典RCU中,这一对字段可能是一个布尔变量。这个字段由根rcu_node 结构的锁进行保护。但是频繁的在没有这个锁保护的情况下访问(但是不修改)。...()和rcu_cpu_notify代码 上图展示了rcu_needs_cpu()和rcu_cpu_notify()的代码,它们被LINUX内核调用,以检查 dynticks-idle 模式转换并处理CPU...(由于篇幅关系,后面的无法贴下,关心原文的,请直接联系谢宝友老师) "Linux阅码场"是专业的Linux及系统软件技术交流社区,Linux系统人才培养基地,企业和Linux人才的连接枢纽。

    3.2K20

    Linux应用层协议:HTTP和HTTPS

    那么有没有其他大佬针对应用层的某些使用场景,已经提前给我们写好了协议软件呢?有,这个协议就是http协议,我们当时的协议仅仅是针对计算场景所设计的,而http协议主要是针对web场景所设计的。...我用我的电脑和手机分别访问了云服务器,所以两个操作系统版本分别为x64架构的win10和基于linux的Android 13操作系统。...除将HTML文件返回给浏览器外,我们也可以将图片文件返回给浏览器,两者本质是相同的,因为在Linux下一切皆文件!...别跟我说你是音频 视频 网页 还是什么乱七八糟的东西,我linux服务器不管这些,我只认文件,无论是什么到linux这里全都是文件,所以无论返回给浏览器什么,其实无非都是把文件内容按照二进制的方式先读取到缓冲区中...需要明确的是http和https只是在技术上有交集,但在应用层两者是完全不同的协议。

    21430

    应用层

    目标: 网络应用的原理:网络应用协议的概念和 实现方面 传输层的服务模型 客户-服务器模式 对等模式(peer-to-peer) 内容分发网络 网络应用的实例:互 联网流行的应用层协 议 HTTP...通过网络基础设施提供的服 务,应用进程彼此通信 如Web: Web 服务器软件与浏览器软件 通信 网络核心中没有应用层软件 网络核心没有应用层功能 网络应用只在端系统上存在 ,快速网络应用开发和部署...应用层协议原理 网络应用的体系结构 客户-服务器模式(C/S:client/server) 对等模式(P2P:Peer To Peer) 混合体:客户-服务器和对等体系结构 1....SSL : 在TCP上面实现,提供加密的TCP连接 基本上是在应用层, 但是也可以在传输层。...Found 请求的文档在该服务上没有找到 505 HTTP Version Not Supported Trying out HTTP (client side) for yourself 在自己的linux

    8110

    Linux应用层查看系统时间的方法

    一、基本概念:     1、linux系统时间和硬件时间:     系统时间:一般来说就是我们执行date命令查看到的时间,Linux系统下所有的时间调用(除了直接访问硬件时间的命令)都是使用这个时间...时区东为正,西为负,例如在中国,本地时间都是使用北京时间,在Linux上就是CST(China Standard Time,中国标准时,注意美国的中部标准时Central Standart Time也缩写为...5、last rebbot查看Linux系统最后一次启动时间 ?     6、还有一些top、w也可以查看到时间 ? ?...四、计算系统时间的程序     时间对操作系统来说非常重要,从内核级到应用层,时间的表达方式及精度各部相同。linux内核里面用一个名为jiffes的常量来计算时间的滴答数。...而应用层,可以利用time()、localtime()等函数,通过tm结构体得到系统时间。

    4.1K01

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

    这不是一篇单独的文章,这是《谢宝友:深入理解Linux RCU》系列的第2篇,前序文章:《谢宝友:深入理解 Linux RCU 从硬件说起之内存屏障》 作者简介:谢宝友,在编程一线工作已经有20年时间...,其中接近10年时间工作于Linux操作系统。...该书作者Paul E.McKeney是IBM Linux中心领导者,Linux RCU Maintainer。...《深入理解RCU》系列文章整理了Paul E.McKeney的相关著作,希望能帮助读者更深刻的理解Linux内核中非常难于理解的模块----RCU。...其目的是为了后续文章中,更好的讲解RCU。因此,并不会对内存屏障进行深入的剖析。但是,对于理解RCU来说,本文中的内存屏障知识已经可以了。

    7.1K44

    应用层

    ---- 应用层 前言 打算系统学习下计算机网络,就来翻阅经典的自顶向下 本篇是第二章应用层,学习有关网络应用的原理和实现方面的知识,涉及开发运行在TCP和UDP上的网络应用程序。...2、UDP 不提供不必要服务的轻量级运输协议,它仅提供最小服务 无连接,因此在两个进程通信前没有握手过程 不可靠数据传送服务 3、对应的应用层协议 (5)应用层协议 应用层协议定义了 交换的报文类型...,例如请求报文和响应报文 各种报文类型的语法,如报文中的各个字段及这些字段是如何描述的 字段的语义,即这些字段中的信息的含义 确定一个进程何时以及如何发送报文,对报文进行响应的规则 有些应用层协议是由RFC...文档定义的,因此它们位于公共域中;还有很多别的应用层协议是专用的,有意不为公共域使用 2、Web 和 HTTP (1)HTTP概况 Web的应用层协议是超文本传输协议(HyperText Transfer...P2P体系有 画图直观可见 6、套接字编程 使用UDP的C-S体系 使用TCP的C-S体系 一些相关代码可参见《Python黑帽子:黑客与渗透测试编程之道》读书笔记(一):网络基础 结语 应用层主要是

    61021
    领券