FFS in Unix

目录

旧文件系统

新文件系统

存储优化

文件系统可以被配置

分布优化

性能


FFS.pdf (berkeley.edu)

这是一个介绍的是关于Unix文件系统革新的文章。

旧文件系统

早在贝尔实验室时期下的Unix文件系统是简单的——文件系统被用作是以组织磁盘的1种数据结构而诞生的它把每一个硬盘划分成一个或者多个的分区每个或者这些个分区上依次建立一个文件系统(注意这时是没有子文件系统一说的)。我们拿一个空闲链表来维护空闲的区域 。

在这个传统的文件系统当中每一个文件可以被独立的标识为是一个目录还是一个具体的字符块文件我们使用一个数据结构来描述他们:那就是inode。对于一个具体的文件inode会存储磁盘上属于这个文件范畴的块的编号。对应于那些特别大的文件——inode自身构成一个类于多孩子树一样的东西(高级inode有最多128个低级inode孩子。。。递归直到最底层的inode,那些确实在维护块号的inode),每一个底层的inode维护的块大小是固定的——512B

新文件系统

新文件系统是这样组织的!每一个或者硬盘可以有多个文件系统。一个文件系统是被他的超级块所描述。这个超级块放在文件系统的头部,因为超级快是有关键的数据,所以他会被多次拷贝(放到下面我要提到的cylinder group里)以防止这些关键信息的丢失造成灾难性的后果

这样的一些工作只会在文件系统被创立时才会产生!里头的数据中关于文件系统自身信息的描述并不会发生改变!一个描述文件系统的文件系统块是4096字节,而事实上这些文件系统块的大小可以是4096字节的2的整数倍或者最小就是4096字节!

在新的文件系统里硬盘被划分为一个或者多个叫做扇区组的东西。一个扇区组是由一个或者多个连续的扇区组成的!每一个这样的扇区组的前列都会有一些薄记信息来进行一定的维护。这些薄记里就有着超级块的备份拷贝,这些inodes结构体。还有一个位图来描述剩余可用的空间,还有其他更多详细的相关信息!其传统的政策是分配一个inode来维护磁盘组中每2048字节的空间大小!

存储优化

新文件系统的信息叫旧文件系统的信息有一个巨大的优化就是存储上的利用率提升了在旧的文件系统中无论这个文件有多小它都必须浪费一定的空间用一个block来存储,空间存在一定的浪费。

为了缓解这样的浪费我们会把一个一个扇区分为两个四个或者是八个的分片,而每一个这样的分片都是可寻址的!一般而言每一个分片的大小是一个硬盘分区的大小也就是512比特。在这里我们仍然会使用位图来描述分片哪些分片是空闲的!

所以在这个新的文件系统里,为这个文件分配硬盘的存储空间是遵循以下步骤的:

  1. 如果这里有足够的空间来维护这个被新追加的文件那么这个足够的空间就会直接被写入这些可用的空间中

  2. 如果这个文件你并没有包含被分片了的块或者说最后一块的剩余空间写不下这些全新的数据如果这个块已经被分配了或者说是被完全分配的那么这个空间将会被填充一些新的数据。如果还有剩那么一个完整的块将会被分配,然后写入这个新的数据,这个过程将会来回往复的持续。直到少于一个完整的块的新数据还被剩余没有被写入,那么接下来这些少于一个快的新数据将会分配以恰好容纳这些新数据的分片数量的空间,随后将这些新数据写入这组分片数量后我们结束文件的追加写入(也就是说那些没有被分片的会将会直接分配以新的足够容纳的块加上最后几个零散的扇区以存放新追加的数据)

  3. 这个文件已经有了一个或者多个这样的分片,那么这个新的数据大小加上原先已经有了在分片中就数据的大小的和大于了一个完整的块!那么一个新的块将会被分配,这些分片的内容将会被拷贝到这个全新的块的起始,以及剩下的内容将会填充新数据!在之后大于一个块的余下数据这个过程跟我们在2中所描述的完全一致!

文件系统可以被配置

这里简短的说一下因为旧的文件系统中所有的参数是被写死的而在新的文件系统中程序员可以根据自身的需求进行一定的参数优化比如说最小块的大小如何一个inode可以维护多大的空间等等

分布优化

文件系统的布局政策被分为两个截然不同的部分。在顶层则是全局的一些策略,在底下这一层则是关于每一个扇区分组的一些策略!这两套方法共同来提升文件系统的性能以减少磁盘搜寻所需最小数量。

我们操纵的就是管理我们如何分配数据结构,怎样分配数据结构来进行文件系统的优化。

一个我们可以操纵的资源那就是inode,inode被用来记描述文件也可以用来描述目录我们尽可能的把所有的inode的分在同一个扇区组内这样我们就可以减少磁盘搜寻次数也就是一次搜寻就可以拿到所有的inode进而管理到所有的文件

另一个呢就是数据块也就是inode指向的对象,我们尽可能会把这些数据会紧凑地放在一起!办法是如下的:

  1. 首先它会优先尝试使用下一个临近的块,这个块应当不用怎样磁盘的旋转就可以找到(同一个扇区,旋转时间几乎不记)

  2. 如果在同一个扇区内没有剩余的块那么我们会去搜寻同一扇区组内空闲的块

  3. 如果整个扇区组都满了我们呢会用哈希表映射临近的扇区组去那个组里寻找空余的块

  4. 如果这个办法已失效了我们则会在全局寻找空闲的块

性能

可以参考文献

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/846678.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

“人工智能AI+” 应用场景盘点

在这个科技与梦想交相辉映的时代,人工智能已不再停留于遥不可及的概念构想,而是化身为一股汹涌的创新洪流,深刻塑造着社会的每一个角落。从文化艺术的智慧火花到生命科学的精密探索,从工业制造的革新升级到日常生活的细致入微&…

Delphi使用TMS.MQTT开发Mqtt客户端

服务端用的是 mosquitto ,下载地址Download | Eclipse Mosquitto 安装完成后需要配置 找到安装目录:mosquitto.conf,打开后修改 allow_anonymous false(禁止匿名登录),password_file D:\Program Files\mosquitto\pwfile.example(密码存放位置) 创建新用户,安装目录…

Least-Squares Rigid Motion Using SVD——文献精读(使用 SVD 方法求解 ICP 问题)

一、文章信息与摘要 文章标题:Least-Squares Rigid Motion Using SVD(使用奇异值分解的最小二乘刚性运动) 说明本文的核心目标:计算对齐两组对应点的最佳拟合刚性变换的步骤 二、问题描述 假设P{p1,p2,...,pn}和Q{q1,q2,...,qn…

Feature Manipulation for DDPM based Change Detection

基于去噪扩散模型的特征操作变化检测 文章提出了一种基于去噪扩散概率模型(DDPM)的特征操作变化检测方法。变化检测是计算机视觉中的经典任务,涉及分析不同时间捕获的图像对,以识别场景中的重要变化。现有基于扩散模型的方法主要…

C++ 习题精选(2)

目录 1. 验证回文串2. 字符串相乘 1. 验证回文串 题目描述:如果在将所有大写字符转换为小写字符、并移除所有非字母数字字符之后,短语正着读和反着读都一样。则可以认为该短语是一个 回文串 。字母和数字都属于字母数字字符。给你一个字符串 s&#xff…

Vue01-vue的简介

一、Vue是什么? 一套用于构建用户界面的渐进式javaScript框架。 构建用户界面: 渐进式: 目前Vue的地位:生态完善,国内前端工程师必备技能。 二、Vue的特点 一个XXX.vue就是一个组件,封装的概念&#xff0c…

threejs的三维前端项目用THREEPlaneGeometry创建平面几何体对象的方法

在 Three.js 中,可以使用THREE.PlaneGeometry类来创建平面几何体对象。THREE.PlaneGeometry类用于创建一个具有指定宽度和高度的平面几何体。 艾斯视觉作为行业ui设计与前端开发服务商很高兴能在这里与你共同探讨:以下是一个示例代码,展示了如…

2023职称继续教育--新时代如何培养和造就未来科技创新领军人才

单选题(共7题,每题5分) 1、《深入实施新时代人才强国战略 加快建设世界重要人才中心和创新高地》指出,到()年,形成我国在诸多领域人才竞争比较优势,国家战略科技力量和高水平人才队伍…

文心一言 VS 讯飞星火 VS chatgpt (272)-- 算法导论20.2 7题

七、试说明如果 PROTO-vEB-MINIMUM 中的第 9 行被执行,则proto-vEB 结构为空。如果要写代码,请用go语言。 文心一言: 在 PROTO-vEB-MINIMUM 算法中,我们假设你指的是一个基于位向量(bit-vector)的扩展二进…

【杂项】几个快捷键提高你的办公效率(装13使用)

前言 其实在Windows下不同的IDE也支持在文本编辑的时候,让你不需要使用鼠标也能够快速的操作。下面以VSCODE为例子 从当前位置开始选中 shift 键盘下键多行插入 ctrl alt 鼠标下键 退出多行插入esc回到一行文字开头 Home 键,回到一行文字结尾 End。…

OSG学习记录

学习自OpenSceneGraph Quick Start Guide的中文版,建议学习书(比较全面) OSG的内存管理机制 程序保存一个指向根节点的指针,不保存场景图形中其他节点的指针。根节点将直接或间接地“引用”场景图形中的所有的节点。 当应用程序…

回溯算法 -- 77. 组合

目录 一.题目描述 二.解题思路 三.回溯三部曲 3.1确定递归函数的返回值以及参数 3.2回溯算法的终止条件 3.3确定单层循环搜索逻辑 四.具体的代码 一.题目描述 给定两个整数 n 和 k,返回范围 [1, n] 中所有可能的 k 个数的组合。 你可以按 任何顺序 返回答案…

【数据结构与算法 | 堆篇】力扣215

1. 力扣215 : 数组中的第k个最大元素 (1). 题 给定整数数组 nums 和整数 k,请返回数组中第 k 个最大的元素。 请注意,你需要找的是数组排序后的第 k 个最大的元素,而不是第 k 个不同的元素。 你必须设计并实现时间复杂度为 O(n) 的算法解…

【Linux】进程间通信(System V IPC)

这节我们开始学习System V IPC方案。 分别是共享内存,消息队列与信号量 会着重讲解共享内存,但是消息队列与信号量只会说明一下原理。 原因:System V是新设计的一套标准 与文件的整合度不高只能进行本地通信 更何况,我们现在有…

代码随想录三刷day52

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、力扣417. 太平洋大西洋水流问题二、力扣827. 最大人工岛三、力扣127. 单词接龙四、力扣841. 钥匙和房间 前言 岛屿问题最容易让人想到BFS或者DFS&#xff0…

若依开发-数据库修改密码

若依忘记密码 在SecurityUtils类添加 public static void main(String[] args) {System.out.println(SecurityUtils.encryptPassword("admin123"));}即可打印出加密后密码

向数据库插入一条数据同时获取主键id

首先创建一个对象 将这个对象使用mybatis插入数据库 Student stu new Student(null, "stu", 18, null); mapper.insertEntity(stu); System.out.println(stu); 在mapper.xml文件中开启配置之后输出传入的stu对象就会有主键id回传 <!-- 插入语句示例 int ins…

探索安全之道 | 企业漏洞管理:从理念到行动

如今&#xff0c;网络安全已经成为了企业管理中不可或缺的一部分&#xff0c;而漏洞管理则是网络安全的重中之重。那么企业应该如何做好漏洞管理呢&#xff1f;不妨从业界标准到企业实践来一探究竟&#xff01;通过对业界标准的深入了解&#xff0c;企业可以建立起完善的漏洞管…

谷歌发布文生视频模型——Veo,可生成超过一分钟高质量1080p视频

前期我们介绍过OpenAI的文生视频大模型-Sora 模型&#xff0c;其模型一经发布&#xff0c;便得到了大家疯狂的追捧。而Google最近也发布了自己的文生视频大模型Veo&#xff0c;势必要与OpenAI进行一个正面交锋。 Veo 是Google迄今为止最强大的视频生成模型。它可以生成超过一分…

计算机网络 3.7广域网

第七节 广域网 一、认识广域网 1.定义&#xff1a;一个范围广的计算机网络&#xff0c;在地理上可以跨越很大的距离&#xff0c;实现局域网资源共享与广域网共享的结合。 2.组成&#xff1a;通信子网、资源子网。 3.主要设备&#xff1a;路由器、调制解调器&#xff0c;通信…