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

300来行代码带你实现一个能跑的最小Linux文件系统

本文以Linux内核为例,用一种稍微不同的方式去描述文件系统的实现。...嗯,我会分3个部分来介绍Linux内核的文件系统: Linux文件系统在不同视角下的样子 实现一个很小但能跑的文件系统 接下来要做什么 本文中,我会通过一个实实在在的文件系统实现的例子,试图阐述 实现一个文件系统...Linux文件系统在不同视角下的样子 当然,在给出最简单的tinyfs实现之前,还是会有一个总体的介绍。...然而确实,我没有找到简单的 最小文件系统 实现,也许你会说Linux内核自带的ramfs难道不就是一个现成的吗?...,你会窥见并掌握Linux内核文件系统的全貌和细节。

4.9K10

LInux中的查找

LInux中的查找 一、grep 二、find 2.1 基本用法 2.2 -exec 命令选项 2.3 配合 xargs 命令 三、awk 一、grep Global Regular Expression...1、查找时不区分字符串的大小写 grep -i ${“查找的字符串”文件名} 2、查找时使用正则表达式,匹配符合的字符串 grep -e ${“正则表达式”文件名} 3、查找不匹配指定字符串的行: grep...-v ${“被查找的字符串”文件名} 4、查找时显示被查找字符串所在的行数 grep -n ${“查找的字符串”文件名} 5、其他 -q 或 --quiet或--silent : 不显示任何信息。...-fstype,- aount,- follow在文件系统、挂载点、链接文件中查询。...-amin n 查找系统中最后N分钟访问的文件 -atime n 查找系统中最后n*24小时访问的文件 -cmin n 查找系统中最后N分钟被改变文件状态的文件 -ctime n 查找系统中最后

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

    查找排序数组的最小值(js)

    题目 在由小到大已排序的未知数组中,以某个元素为支点旋转(好比将序列沿着前后顺序围成环移动)得到了一个数组,请找出该数组的最小值。...请找出旋转后数组的最小值(假定数组中没有重复数字)。 解 答: Math.min(), 卒。。。...从旋转点分开的两段数组都是有序的,而且前面数组的值都要大于后边子数组的元素,所以要找的旋转后数组的最小值也就是两个有序数组的分界线。...所以有点像数学中的夹逼准则,有两个指针分别从数组开头和结尾想目的地不断逼近,直到缩小的范围成为一个点,则是目标值。...,arr[mid]不可能是最小值 9 start=mid+1 10} 11else { 12 // 对于原本升序的数组,此时arr[mid]有可能是最小值 13 end= mid 14

    2.9K40

    fat文件系统查找、删除、创建目录

    Fat文件系统查找过程 查找一个文件是通过文件名查找的,对于fat文件系统,可以直接从vfat_lookup函数看 主体流程如下: vfat_lookup vfat_find fat_search_long...)查找一个没使用过的编号填充到inode->i_ino,通过都是从1开始往后分配,inode->i_ino就像是身份证一样的信息,区别每个inode,这个我们调试一些文件系统问题的时候通常会用到它。...,主要是要理解几个关键的结构体、inode,目录项这几个重要的东西在查找中的作用。...,那么查找的时候先判断de->name[0]如果是DELETED_FLAG就跳过了,不记得可以往上看回查找过程,一个是释放簇(在fat表写为0),数据区不变。...,往下就是释放簇 fat文件系统创建目录 fat_alloc_new_dir就是创建目录的函数,可以看到,创建的时候先在fat表找到一个未使用的簇号,分配出来,然后fat_clus_to_blknr函数通过该簇号计算出扇区编号

    1.8K40

    Linux文件系统的实现

    比如cat可以打开文件,读取数据,最后在终端显示: $cat test.txt 对于Linux下的程序员来说,了解文件系统的底层组织方式,是深入进行系统编程所必备的。...即使是普通的Linux用户,也可以根据相关的内容,设计出更好的系统维护方案。 存储设备分区 文件系统的最终目的是把大量数据有组织的放入持久性(persistant)的存储设备中,比如硬盘和磁盘。...分区表说明了对应分区的起始位置和分区的大小。 我们在Windows系统常常看到C分区、D分区等。Linux系统下也可以有多个分区,但都被挂载在同一个文件系统树上。 数据被存入到某个分区中。...要注意的是进程fork之后的情况,子进程将只复制文件描述符的数组,而和父进程共享内核维护的文件表格和inode。此时要特别小心程序的编写。 总结 这里概括性的总结了Linux的文件系统。...Linux以inode的方式,让数据形成文件。 了解Linux的文件系统,是深入了解操作系Linux原理的重要一步。

    1.8K60

    Linux的proc文件系统

    proc,用户空间和内核空间能够通过该接口通信, 与普通文件不同的是。这些虚拟文件的内容都是动态创建的。 proc文件系统是一个伪文件系统,它仅仅存在内存其中,而不占用外存空间。...它以文件系统的方式为訪问系统内核数据的操作提供接口。用户和应用程序 能够通过 proc得到系统的信息。并能够改变内核的某些參数。 proc 文件系统能够被用于收集实用的关于系统和执行中的内核的信息。...对此文件系统的訪问同一般文件同样。...内核运行的上下文转换次数 cat /proc/stat|grep ctxt|awk'{print $2}’ 6.系统创建的进程数 cat /proc/stat|grep processes|awk...'{print $2}’ 7.当前可用的内存数量 cat /proc/meminfo|grep MemFree 版权声明:本文博客原创文章。

    2.9K10

    Linux的文件系统(3)

    本章学习目标: 掌握Linux下文件目录的属性 掌握Linux下的权限管理 掌握如何切换用户身份及权限委派 3.1文件系统简介 文件系统(File system)泛指储存在计算机上的文件和目录。...3.2 linux支持的文件系统类型 目前比较流行的操作系统是Windows和Linux。Windows常用的分区格式有三种,分别是FAT16、FAT32、NTFS格式。...3.2.2 Linux文件系统介绍 一、Ext2 Ext2是GNU/Linux系统中标准的文件系统。...三、Linux swap 它是Linux中一种专门用于交换分区的swap文件系统。Linux是使用这一整个分区作为交换空间。一般这个swap格式的交换分区是主内存的2倍。...Red Hat Linux根据文件系统层次标准(FHS)将文件组织成目录: / 根目录。所有其他目录都在文件系统层次的根目录之下。换句话说,它们是子目录。

    3K30

    linux文件系统

    目录 c语言文件操作: linux文件系统调用: open: 标志位传参: 虚拟文件系统: write: close: 跨平台性: c语言文件操作: 先来简单回顾一下c语言的文件操作,...linux文件系统调用: 在linux中,我们还可以使用系统调用来对文件进行修改,我们来认识几个系统调用接口: open: 我们先在linux下查一下这个函数的系统调用手册...虚拟文件系统: 回到open函数,可以注意到之前的代码,open函数有一个返回值,这个返回值是这个文件的文件标识符,一个进程,可能会打开很多文件,当一个文件被打开会创建一个struct files来描述这个文件...这套文件系统被称为虚拟文件系统 。 所以我们的操作系统在对文件进行操作时,只认文件描述符fd!!! write: 这里传fd的作用,想必不需要我多讲了,这个函数功能应该很明了了。...主要是为了提高的代码的可移植性,跨平台性,在linux里的系统调用是open,可能在windows里面的系统调用又不一样,所以c语言不得不这么做,而且c语言的fopen等函数里面一定封装了linux系统调用的

    10710

    【Linux】文件系统

    上一篇博客:【Linux】磁盘结构和文件系统 Group中的组成部分 下面是每个group的组成部分,但是super block不是每个组都有的,这个点后面详谈。...inode table inode table 是 Linux 文件系统(如 Ext2、Ext3、Ext4)中用于存储 inode 的一张表格。...在 Linux 文件系统(例如 Ext2、Ext3、Ext4)中,inode bitmap 是块组元数据的一部分,用来跟踪某个块组内 inode 的使用情况。...block号,我们也只需要记录每个组的起始位置的号,这个信息一般记录在GDT当中,当我们查找一个文件的时候,只需要拿到给定的inode,然后拿着这个inode在GDT中查找这个inode是属于哪个分组的...Linux的目录中存放的是文件名和inode的映射关系,因为同一级目录下不可能存在同名文件,所以索引都是1:1,唯一的。 为什么Linux会这么做呢?

    13210

    linux文件系统

    Linux是一个基于Unix的操作系统,具有强大的文件系统功能。Linux文件系统是在硬盘上组织和存储数据的一种结构,通过文件系统可以管理文件、目录、权限等信息。...在Linux中,文件系统被组织成一个树形结构,称为文件系统层次结构(Filesystem Hierarchy Standard,FHS),该标准规定了Linux操作系统中各级目录的名称和用途,使得Linux...根目录 根目录(/)是Linux文件系统中的最顶层目录,所有其他的目录和文件都是从根目录开始构建的。在根目录下可以存放各种文件和目录,如用户目录、系统文件、配置文件等。.../proc /proc目录是Linux系统中一个特殊的目录,用于提供进程和系统信息的虚拟文件系统。.../mnt /mnt目录是Linux系统中用于挂载文件系统的目录,通过挂载可以将其他文件系统的内容挂载到/mnt目录下,使得这些文件系统可以被访问。

    8.8K00

    【Linux】文件系统

    (如何管理磁盘文件) 5.1 了解文件系统 有了上面的线性大地址,我们就可以开始构建出文件系统了。...文件在磁盘中存储,本质是储存文件的内容与文件的属性数据。在每个分区内部分组,然后写入文件系统的管理数据,称之为格式化!!! Linux 文件系统特定: 文件属性 与 文件内容 分开存储。...inode 表 : 存放文件属性 如 文件大小,所有者,最近修改时间等 Linux中文件的属性是大小固定的集合体(一般固定128字节) 不包含文件名,但是都有inode_number,通过inode号来标识一个文件...那目录的内容是什么呢?目录内容就是文件名与其inoded 映射关系。 这也可以解释一下我们平时的应用: 同一目录下不难创建同名文件 查找文件的顺序,先查找文件名->再找到映射的inode编号。...而Linux系统会进行路径的缓存,来方便我们的寻找工作。 我们一般使用的云服务器会有一个虚拟磁盘vda,系统中会有许多分区。

    11610

    Linux文件系统

    文件系统 磁盘 磁盘的物理结构 磁盘的储存结构 磁盘的逻辑结构 文件系统 分治 inode与数据块 软硬链接 什么是软硬连接 文件与引用计数 文件的三大时间 动静态库 什么是库 库的使用 静态库...如果想清空哪个盘里面的所有数据内容,其实就相当于重写文件系统。一个磁盘,第一步是分区,第二部就是格式化,也就是写入文件系统。 文件系统的信息有分区的使用状态,分区的每个组的状态和信息。...inode与数据块 文件 = 内容 + 属性 Linux中,文件的属性和内容是分批存储的。 保存文件属性的叫inode块:具体大小跟文件系统的版本有关,我的是ext3,128字节。...Group Descriptor Table:块组描述表,对应分组的宏观属性信息。 在查找一个文件的时候统一用的是inode编号,它可以跨组的,不同的组里面是不同的,但是不能跨分区。...data block blocks[15]是储存数据块的,假设某个inode编号对应的数据块是这样存储的: 那么,如果inode拿到了对应的这个编号,我们要查找内容就找data block blocks

    12.6K00

    常见的linux文件系统

    文件系统: 它们不是世界上最激动人心的技术,但是仍然很重要。本文我们将细数那些流行的 Linux 文件系统 - 它们是什么,它们能够做什么,以及它们的目标用户。...BtrFSB 树(B-tree)文件系统 (也被当做是 butterFS,黄油文件系统) 是 Oracle 为 Linux 研发的一款文件系统。它是一个全新的文件系统,而且正处于主要开发阶段。...Linux 社区认为其有时候使用上还有些不稳定。BtrFS 的核心原则是围绕着写时复制copy-on-write原则展开的。写时复制基本上意味着在写入数据完成前,这份数据的每一比特都有单独的一份副本。...目标用户:BtrFS 的开发者们许诺过,该文件系统是当前其他文件系统的新一代替代者。非常正确,虽然目前其处于开发中。...结论Linux 上有许多可用的文件系统。每个文件系统都有其特定的用途,以便于特定用户解决不同的问题。本文的焦点集中在 Linux 平台上文件系统的主流选择。毫无疑问,其它的场景下还有一些别的选择。

    1.8K40

    linux 的文件系统 (3)

    接下来我们就在分区上创建文件系统。 linux 下用 mkfs 来创建文件系统          用法 : mkfs  -t  文件系统类型  设备名称    创建 ext3 文件系统 ?  ...创建 FAT32 文件系统 (Linux 把  FAT32 识别为 vfat ) ? 下面重点讲一下 专门管理 ext 系列文件的  mke2fs .   ...(详情请自行  man  mke2fs)    mke2fs  命令常用的选项如下所示: -t : 用来指定文件系统的类型,可以是 ext2 , ext3 ,也可以是 ext4 。                      ...创建一个 ext3 文件系统 ,块大小为 4096,并且预留给超级用户的块数百分比为 3 ? 接下来说一下  blkid  命令这个命令可以查看设备的相关属性。   ...fsck : 检查并修复 linux  文件系统类型     -t  :   FILESYSTEM     -a :    自动修复(不询问自动完成修复) e2fsck :  专门修复 ext2 ext3

    1.9K10

    Linux文件系统的实现

    比如cat可以打开文件,读取数据,最后在终端显示: $cat test.txt 对于Linux下的程序员来说,了解文件系统的底层组织方式,是深入进行系统编程所必备的。...即使是普通的Linux用户,也可以根据相关的内容,设计出更好的系统维护方案。 存储设备分区 文件系统的最终目的是把大量数据有组织的放入持久性(persistant)的存储设备中,比如硬盘和磁盘。...分区表说明了对应分区的起始位置和分区的大小。 ? 我们在Windows系统常常看到C分区、D分区等。Linux系统下也可以有多个分区,但都被挂载在同一个文件系统树上。 数据被存入到某个分区中。...要注意的是进程fork之后的情况,子进程将只复制文件描述符的数组,而和父进程共享内核维护的文件表格和inode。此时要特别小心程序的编写。 总结 这里概括性的总结了Linux的文件系统。...Linux以inode的方式,让数据形成文件。 了解Linux的文件系统,是深入了解操作系Linux原理的重要一步。

    2.7K50

    Linux文件系统

    Linux文件系统 在Linux系统中所有的设备都统称为文件,所以同样必须要去学习下linux文件系统到底是何物??? 进入系统后我们使用命令ls -ll 就可以查看根目录下所有文件的信息 ?...二进制文件:linux中可执行文件(命令) ? 数据格式文件(一种特殊的文件 data) ? 2、d目录文件 ls -ld 可以显示所有目录文件 3、b块设备文件 ?...二:文件的扩展名 同样linux系统中的文件也有扩展名,不过意义不大,只是为了区分不同的文件 linux中常见的扩展名类型有以下几种: 1、.tar .tar.gz .tgz .zip 这类表示压缩文件...其实一个文件真正的信息应该包括9列字段 ?...Inode:索引节点,linux中存储设备或分区被格式化为文件系统后,一般都会分成二个部分,第一部分就是inode,第二部分为block,inode存储的是文件的属性信息,我们可以使用ls -i查看Inode

    9.8K40

    linux文件系统

    Linux 文件系统是 Linux 操作系统中的重要组成部分,它是文件和目录的组织方式,为用户提供了一个良好的管理和访问文件的方式。...Linux 文件系统具有以下特点:一切皆文件:在 Linux 文件系统中,一切都被视为文件,包括硬件设备、目录、文件、管道等等。这种一切皆文件的思想使得 Linux 文件系统非常灵活。.../var:包含系统和应用程序的变量文件,如日志文件、缓存文件等。Linux 文件系统层次结构的设计使得不同的文件和目录可以被组织成一个树形结构,从而方便用户和程序员查找和管理文件。...以下是一些常见的 Linux 文件系统格式:ext2:是 Linux 文件系统的最早版本,它是一个简单的文件系统,不支持日志和数据恢复功能。...查找文件:可以使用find 命令来查找文件,如 find /home -name test.txt。

    8.7K40

    linux文件系统

    Linux 文件系统 操作系统中,用来管理和存储文件信息的软件机构称为文件管理系统,简称文件系统。...每个簇的空间更小,磁盘的利用率更高,并且可以共享资源、文件夹以及对文件设置访问许可权限。 RAW RAW文件系统是一种磁盘未经处理或者未格式化产生的文件系统。...一般来说有这几种可能造成正常文件系统变成RAW文件系统: 没有格式化 格式化中途取消 硬盘出现坏道 硬盘出现不可预知的错误 EXT EXT是扩展文件系统,目前最新的版本是5.0....HFS(+) 苹果电脑上的文件系统。 Linux里的文件系统 不同于Windows系统有盘符的概念(C盘、D盘等),Linux里只有一个盘符,是从 " / " 开始的,只有它是没有上级目录的。.../media Linux系统自动识别的一些设备,比如U盘、光驱等,当识别后,linux会把识别的设备挂载到这个目录下。

    7.3K30
    领券