首页
学习
活动
专区
圈层
工具
发布

图解|Linux文件预读原理

概述 本文主要阐述内核(linux-3.12)的文件系统预读设计和实现。...所谓预读,是指文件系统为应用程序一次读出比预期更多的文件内容并缓存在page cache中,这样下一次读请求到来时部分页面直接从page cache读取即可。...,共进行三次读(且是顺序读),那让我们看看操作系统是如何对文件进行预读的。...由于上面的两次顺序读,截至目前,该文件在操作系统中的page cache状态如下: Read 3 接下来应用程序进行第三次读,顺序读,范围是[page3, page6],上面的预读其实已经将这些页面读入...,根据特定算法计算本次预读大小,更新预读窗口为 (12,16,16) ,新的预读窗口如下: 对该情境简单总结下,由于三次的顺序读加上内核的预读行为,文件的page cache中的状态当前如下图所示:

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

    读Effective C++

    读Effective C++ 2018年一月份读书:《Effective C++:改善程序与设计的55个具体做法》 一月份利用晚上的时间粗读本书,算是对C++基础知识的复习与学习;按照章节顺序来读,前面部分较基础...内容索引 本书共介绍C++程序设计的55个准则,作者已按照类型划分不同分类: 1 基础介绍 通用的也是常用的准则: 了解C++组成。...四部分:基础C, Object-Oriented C++, Template C++(泛型编程), STL(程序库) 用const, enum, inline替换#define 尽可能使用const。...3 资源管理 资源包括动态内存分配,以及文件描述符,互斥锁,数据库连接,sockets等。当你不再使用它时,必须还给系统,否则会导致内存泄漏。...会被编译器替换,免除函数调用开销,但是可能会导致代码膨胀 将文件间的编译依存关系降至最低。 6 继承和面向对象设计 我感觉这是C++的精华部分,也挺重要。 public继承表示is-a关系。

    89520

    fileinput 读文件

    批量打开多个文件 从上面的例子也可以看到,我在 fileinput.input 函数中传入了 files 参数,它接收一个包含多个文件名的列表或元组,传入一个就是读取一个文件,传入多件就是读取多个文件。...Linux的文件 if line[-2:] == "\r\n": line = line + "\n" sys.stdout.write(line) 附:如何实现 DOS...在最后一个文件的最后一行被读取之后,返回此文件中该行的行号。...fileinput.nextfile() 关闭当前文件以使下次迭代将从下一个文件(如果存在)读取第一行;不是从该文件读取的行将不会被计入累计行数。 直到下一个文件的第一行被读取之后文件名才会改变。...Linux的文件 if line[-2:] == "\r\n": line = line + "\n" sys.stdout.write(line) 案例四:配合 re

    3.6K10

    文件系统预读

    是指文件系统为应用程序一次读出比预期更多的文件内容并缓存在page cache中,这样下一次读请求到来时部分页面直接从page cache读取即可。...,共进行三次读(且是顺序读),那让我们看看操作系统是如何对文件进行预读的。...2 这里我们来看另外一种情境:单进程文件顺序读,读大小为256KB,看看预读逻辑如何处理这种情况,照例首先给出事例代码: { ......所谓的交织读指的是多线程(进程)读同一个打开的文件描述符,单个线程的顺序读在操作系统看来可能会变成随机读。...线程1 Read 1 线程1读文件的前两个页面,由于尚未缓存命中,因此会触发文件系统的一次同步预读,确定预读窗口为(ra->start, ra->size, ra->async_size) = (0,

    1.1K20
    领券