FFS in Unix

2024-06-03 04:28
文章标签 unix ffs

本文主要是介绍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. 如果这个办法已失效了我们则会在全局寻找空闲的块

性能

可以参考文献

这篇关于FFS in Unix的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1026001

相关文章

列举你能想到的UNIX信号,并说明信号用途

信号是一种软中断,是一种处理异步事件的方法。一般来说,操作系统都支持许多信号。尤其是UNIX,比较重要应用程序一般都会处理信号。 UNIX定义了许多信号,比如SIGINT表示中断字符信号,也就是Ctrl+C的信号,SIGBUS表示硬件故障的信号;SIGCHLD表示子进程状态改变信号;SIGKILL表示终止程序运行的信号,等等。信号量编程是UNIX下非常重要的一种技术。 Unix信号量也可以

【unix高级编程系列】线程

引言 我们知道unix进程中可以有多个线程,进程中的线程可以访问该进程的所有组成部分。并且CPU的调度单元就是线程。这就面临一个问题:当进程中的临界资源需要在多个线程中共享时,如何解决一致性问题? 本文将从线程的概念、线程的使用方式、unix提供哪些方式解决一致性问题进行介绍,加深对线程的理解。 线程概念 线程的优点: 简化代码结构。比如在业务上为每种事件类型分配单独的处理线程,可以

linux的nohup命令的用法。在应用Unix/Linux时,我们一般想让某个程序在后台运行,于是我们将常会用 在程序结尾来让程序自动运行。比如我们要运行mysql在后台: /usr/local

在应用Unix/Linux时,我们一般想让某个程序在后台运行,于是我们将常会用 & 在程序结尾来让程序自动运行。比如我们要运行mysql在后台: /usr/local/mysql/bin/mysqld_safe –user=mysql &。可是有很多程序并不想mysqld一样,这样我们就需要nohup命令,怎样使用nohup命令呢?这里讲解nohup命令的一些用法。 nohup /root/

【Unix编程】进程间通信(IPC)

进程间通信(IPC,InterProcess Communication)是指在不同进程之间传播或交换信息。IPC的方式通常有管道(包括无名管道和命名管道)、消息队列、信号量、共享存储、Socket、Streams等。其中 Socket和Streams支持不同主机上的两个进程IPC。 一、管道 管道,通常指无名管道,是 UNIX 系统IPC最古老的形式。 1、特点: 它是半双工

Unix与Linux的关系

Unix 和 Linux 之间有着密切的历史和技术联系,尽管它们是两个独立的操作系统。 Unix 的历史 Unix 的历史可以追溯到1969年,当时 AT&T 的贝尔实验室的工程师肯·汤普逊(Ken Thompson)和丹尼斯·里奇(Dennis Ritchie)开始开发 Unix 操作系统。Unix 设计之初是为了方便进行程序开发工作,它强调的是多用户、多任务的能力,以及良好的文件系统支持。

【docker无法启动】 can't create unix socket /var/run/docker.sock: is a directory

一次重启docker后出现的问题 Oct 18 19:18:20 worker systemd[1]: Starting Docker Application Container Engine...Oct 18 19:18:20 worker1 dockerd-current[118257]: time="2018-10-18T19:18:20.734668371+08:00" level=w

在 Linux 和类 Unix 系统中,终端(Terminal)和 Shell

在 Linux 和类 Unix 系统中,终端(Terminal)和 Shell 是两个相关但不同的概念。以下是它们的定义和关系: 1. 终端(Terminal) 终端 是一个用于与计算机交互的用户界面。它可以是一个物理设备(如早期的硬件终端)或一个软件应用程序(如现代的终端模拟器)。终端提供了一个输入和输出的窗口,用户可以在其中输入命令,并查看计算机的响应。 物理终端: 在早期计算机中,物

Linux和Unix的区别及为什么鸿蒙系统不用Unix的原因

目录 Linux是什么? Unix是什么? 他们的区别: 鸿蒙系统介绍及鸿蒙系统不用Unix的原因 Linux是什么? Linux的历史可以追溯到1991年,由芬兰的计算机科学家林纳斯·托瓦兹(Linus Torvalds)为了学习操作系统的工作原理而开始编写的个人项目。Linux的起源与Unix操作系统有着密切的联系,Unix最初由Ken Thompson和Denni

Unix环境高级编程开篇-apue.h配置

书就不多说了,被称为Unix下C编程的圣经;不过现在国内貌似部分人都喜欢向别人推荐书,我很怀疑着部分人是不是推荐的每一本都看过。这个我暂时也不敢推荐,因为我也没有看完。 这本书上几乎所有的代码都用到了作者编程的一个头文件:apue.h,但是这个不是ISO C自带的,所以需要配置一下。 我用的这本书是第三版,第三版,第三版 重要的事情说三遍 1:先去这本书的官网把源代码下载下来,传送门 2:

linux/UNIX体系结构图

以上是linux结构图 以下是UNIX体系结构图 <script>window._bd_share_config={"common":{"bdSnsKey":{},"bdText":"","bdMini":"2","bdMiniList":false,"bdPic":"","bdStyle":"0","bdSize":"