首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Boltdb源码分析(一)-------page结构

    源码比较多,且其内部逻辑比较复杂,本文只分析其中的page结构。 github.com/boltdb/bolt/page.go ? page结构体。...page指的是内存中的页,这个结构体其实是用来对应页,然后将其管理起来的数据结构。 id:是pgid类型,是给page的编号。 flags:是指的此页中保存的具体数据类型。...在Linux内核中经常用到。比如典型的场景就是虚拟文件系统的接口。 ? ? 这个是具体的数据类型。上面写的有4种。...page的头部包含了一些信息,最后的ptr是具体的数据结构。 ? 获取到meta格式的数据结构 ?...meta相对比结构会固定,但内容更多 后续文章再分析吧 龚浩华 月牙寂道长 QQ 29185807 2018年04月03日

    80630

    【图解Linux内核】Page Cache

    这些问题,很可能是由于Page Cache管理不到位引起的,因为Page Cache管理不当除了会增加系统I/O吞吐外,还会引起业务性能抖动。...认识Page Cache最简单的方式,就是用数据说话,通过具体的数据你会更加深入地理解Page Cache的本质。 为什么需要Page Cache,Page Cache的产生和回收是什么样的。...最好具备一些Linux编程的基础,比如,如何打开一个文件;如何读写一个文件;如何关闭一个文件等等。 什么是Page Cache? Page Cache到底是属于内核还是属于用户?...红色的地方就是Page Cache,Page Cache是内核管理的内存,它属于内核。...怎么观察Page Cache 在Linux上直接查看Page Cache的方式: /proc/meminfo free /proc/vmstat 命令 内容其实是一致的。

    5.7K10

    【图解Linux内核】Page Cache

    这些问题,很可能是由于Page Cache管理不到位引起的,因为Page Cache管理不当除了会增加系统I/O吞吐外,还会引起业务性能抖动。...认识Page Cache最简单的方式,就是用数据说话,通过具体的数据你会更加深入地理解Page Cache的本质。 为什么需要Page Cache,Page Cache的产生和回收是什么样的。...最好具备一些Linux编程的基础,比如,如何打开一个文件;如何读写一个文件;如何关闭一个文件等等。 什么是Page Cache? Page Cache到底是属于内核还是属于用户?...红色的地方就是Page Cache,Page Cache是内核管理的内存,它属于内核。...怎么观察Page Cache 在Linux上直接查看Page Cache的方式: /proc/meminfo free /proc/vmstat 命令 内容其实是一致的。

    5.1K20

    page结构体,何处安放你的灵魂?

    如此海量内存给内核带来了很多挑战,其中之一就是page struct存放在哪里。 page struct的三种存放方式 在内核中,我们将物理内存按照页大小进行管理。...这样每个页就对应一个page struct作为这个页的管理数据结构。 随着内存容量的增加,相对应的page struct也就增加。而这部分内存和其他的内存略有不同,因为这部分内存不能给到页分配器。...commit c4e1be9ec1130fff4d691cdc0e0f9d666009f9ae Author: Dave Hansen Date...如果我们能够通过某种方式将page struct线性映射到页表,这样我们不就能又通过简单的计算来换算物理地址和page struct了么?...内核代码的优美之处就在于,你可能不一定看懂了所有细节,但是从优美的结构上能猜到究竟做了些什么。

    1.4K31

    linux Page cache和buffer cache正解

    Page cache实际上是针对文件系统的,是文件的缓存,在文件层面上的数据会缓存到page cache。文件的逻辑层需要映射到实际的物理磁盘,这种映射关系由文件系统来完成。...当page cache的数据需要刷新时,page cache中的数据交给buffer cache,但是这种处理在2.6版本的内核之后就变的很简单了,没有真正意义上的cache操作。...简单说来,page cache用来缓存文件数据,buffer cache用来缓存磁盘数据。...这个page的数量将会在top程序的buffer一栏中显示。...从上面的分析可以看出,2.6内核中的buffer cache和page cache在处理上是保持一致的,但是存在概念上的差别,page cache针对文件的cache,buffer是针对磁盘块数据的cache

    3K20

    Linux 内核 内存管理】物理内存组织结构 ⑥ ( 物理页 page 简介 | 物理页 page 与 MMU 内存管理单元 | 内存节点 pglist_data 与 物理页 page 联系 )

    文章目录 一、物理页 page 简介 1、物理页 page 引入 2、物理页 page 与 MMU 内存管理单元 3、物理页 page 结构体 4、Linux 内核源码中的 page 结构体 二、内存节点...pglist_data 与 物理页 page 联系 内存管理系统 3 级结构 : ① 内存节点 Node , ② 内存区域 Zone , ③ 物理页 Page , Linux 内核中 , 使用 上述...结构体 " 物理页 " pageLinux 内核 " 内存管理 " 中的 最小单位 , 物理页 中的 " 物理地址 " 是连续的 , 每个 " 物理页 " 使用 struct page 结构体...} 4、Linux 内核源码中的 page 结构体 " 物理页 " 使用 page 结构体 进行描述 , 该结构体又称为 " 页描述符 " ; 该 page 结构体 定义在 Linux 内核源码的 linux...SPARSEMEM */ // 页描述数组 struct page *node_mem_map; #endif } 参考 【Linux 内核 内存管理】物理内存组织结构 ③ ( 内存管理系统三级结构

    6.8K10

    Presto 核心数据结构:Slice、Page、Block

    在 Presto 中,我们需要了解一些非常重要的数据结构,例如,Slice,Block 以及 Page,下面将介绍这些数据结构。 1....Slice 从用户的角度来看,Slice 是一个对开发人员更友好的虚拟内存,它定义了一组 getter 和 setter 方法,因此我们可以像使用结构化数据一样使用内 Slice 常用来表示一个字符串:...因此,让我们在这里总结一下数据是如何结构化的,当要发送一些行时,Presto 将: 将每一列放入单独的 Block 中。 将这些 Block 放入一个 Page 中。 发送 Page。...Page 是保存数据并在 Presto 物理执行算子之间传输的数据结构:上游算子通过 getOutput() 产生输出: /** * Gets an output page from the operator...总结 我们介绍了 Presto 中三个核心数据结构:Slice,Block 和 Page。简而言之,Slice 是对开发人员更友好的虚拟内存,Block 代表列,Page 代表行组。

    2.6K30

    深入理解Linux VFS和Page Cache

    编者注:在分析完 Linux inode 基础概念 之后,让我们看下inode在内存中对应的文件系统抽象VFS,然后分析下关于 磁盘操作 中Page Cache的回写策略。...VFS(虚拟文件系统层) VFS是虚拟文件系统层(进程与文件系统之间的抽象层),与它相关的数据结构只存在于物理内存当中。...其目的是屏蔽下层具体文件系统操作的差异,为上层的操作提供一个统一接口,正是由于VFS的存在,Linux中允许多个不同的文件系统共存。...VFS中包含着向物理文件系统转换的一系列数据结构,如VFS超级块、VFS的Inode、各种操作函数的转换入口等。...Linux中VFS依靠四个主要的数据结构来描述其结构信息,分别为超级块、索引结点、目录项和文件对象,这些数据结构大都会与磁盘上的对应上。 超级块(Super Block):超级块对象表示一个文件系统。

    3.2K21

    Page Cache与Page回写

    理想的做法是释放距离下次访问时间最久的page,但是很明显,这是不现实的。下面先介绍LRU算法,然后介绍基于LRU改进的Two-List策略,后者是Linux使用的策略。...Page Cache在Linux中的具体实现 address_space结构 内核使用address_space结构来表示一个page cache,address_space这个名字起得很糟糕,叫page_ache_entity...(对从用户空间拷贝到内核空间不是很理解,后期会重点学习Linux读、写文件的详细过程然后写一篇详细的blog介绍) Buffer Cache 在Block I/O的文章中提到用于表示内存到磁盘映射的buffer_head...结构,每个buffer-block映射都有一个buffer_head结构,buffer_head中的b_assoc_map指向了address_space。...在Linux2.4中,buffer cache和 page cache之间是独立的,前者使用老版本的buffer_head进行存储,这导致了一个磁盘block可能在两个cache中同时存在,造成了内存的浪费

    1.5K20

    Linux内存描述之内存页面page--Linux内存管理(四)

    内存中的每个节点都是由pg_data_t描述,而pg_data_t由struct pglist_data定义而来, 该数据结构定义在include/linux/mmzone.h, line 615, 每个结点关联到系统中的一个处理器...在典型的系统中, 由于页的数目巨大, 因此对page结构的小改动, 也可能导致保存所有page实例所需的物理内存暴涨....等等. 2.1 struct page结构 内核用struct page(include/linux/mm_types.h?v=4.7, line 45)结构表示系统中的每个物理页....设置PG_slab, 则page属于slab,page->lru.next指向page驻留的的缓存的管理结构page->lru.prec指向保存该page的slab的管理结构。...的状态和其他信息 */ 这些标识是独立于体系结构的, 因而无法通过特定于CPU或计算机的信息(该信息保存在页表中) 3.1 页面到管理区和节点的映射 在早期的linux-2.4.18的内核中, struct

    8.4K11
    领券