zoukankan      html  css  js  c++  java
  • 目录和文件管理

    文件控制块—FCB
    为了能对一个文件进行正确的存取,必须为文件设置用于描述和控制文件的数据结构,称之为“文件控制块”(FCB)
    文件与文件控制块一一对应
    记录文件名及其存放地址、文件的说明和控制信息。(是谁?在哪里?什么权?)
    文件管理程序借助于文件控制块中的信息对文件施以各种操作。
    把文件控制块的有序集合称为文件目录,即一个文件控制块就是一个目录项。通常一个文件目录也被看作是一个文件,称为目录文件。

    对文件实施有效的管理,必须对它们加以妥善组织,主要是两大操作:
    基本信息记录(FCB,目录项)
    方便检索、管理(目录操作)
    目录管理的要求如下:
    实现“按名存取”;(最基本功能)
    提高对目录的检索速度;
    文件共享;
    允许文件重名。

    在文件控制块中,通常含有以下三类信息。
    基本信息类
    包括文件名,文件物理位置,文件逻辑结构,文件的物理结构。
    存取控制信息类
    包括文件主的存取权限,核准用户的存取权限和一般用户的存取权限。
    使用信息类
    建立日期和时间、文件上次修改的日期和时间
    当前使用信息:打开该文件的进程数、是否被进程锁住、是否已修改等。

    2)索引结点
    索引结点的引入
    文件目录占越大量的盘块,需进行的磁盘读写开销越大。减少实际检索的信息量就减少移动磁头的开销,提高速度;
    目录一般是按名检索。而直到找到正确文件前,只关心文件名,不需要其它的文件描述信息,目录中这部分内容的调入不是必须的。
    所以:将文件名、文件具体信息分开,使文件描述信息单独形成一个索引结点。

    3) 目录结构
    目录结构的组织,关系到文件系统的存取速度,也关系到文件的共享性和安全性。
    组织好文件的目录,是设计好文件系统的重要环节。
    目前常用的目录结构形式有
    单级目录
    两级目录
    多级目录
    ①单级目录结构(Single-Level Directory)
    最简单的目录结构。
    整个文件系统中只建立一张目录表,每个文件一个目录项,含有文件相关信息。
    每建立一个新文件:
    先检索所有的目录项,保证文件名唯一。
    获得一空白目录项,填入相关信息,修改状态位(表明每个目录项是否空闲)。
    删除一个文件:
    找到对应目录项,回收文件所占用空间
    清除目录项
    ②两级目录结构( Two-Level Directory )
    为每一个用户建立一个单独的用户文件目录UFD,UFD由用户所有文件的文件控制块组成。
    系统建立一个主文件目录MFD, MFD中每个用户目录文件都占有一个目录项,其中包括用户名和指向UFD的指针。

    两级目录的特点
    基本克服了单级目录的缺点,并具有以下优点:
    提高了检索目录的速度。
    在不同的目录中可重名。
    不同用户还可以使用相同/不同的文件名来访问系统中的同一个共享文件。
    不提供子目录操作,还不方便;各用户之间被完全隔离的话用户访问其他用户文件时,不方便合作。

    ③多级目录结构
    适用于较大的文件系统管理。又称为树状目录(tree-like)
    在文件数目较多时,便于系统和用户将文件分散管理。
    层次结构更清晰、提供更灵活的权限管理等
    但目录级别太多时也会增加路径检索层次,增加磁盘访问时间。

    1)文件共享
    多个用户共享一份文件,只保留文件的一份副本,节约存储空间
    共享范围:单机系统/多主机系统/网络范围
    20世纪六七十年代,出现了若干文件早期共享方法,绕弯路法、连访法等,逐渐发展为现代一些共享方式
    索引结点
    ①索引结点法
    基本FCB法:
    名+详细信息。
    直接在文件目录中包含文件的物理地址,该方法实现的共享不适用文件动态变化。一个用户对文件的修改(如物理块号增加),对其他用户不可见,共享文件的FCB信息记录同步更新困难。
    文件名+索引结点指针。
    一个用户修改指针指向地址里的内容,指针不变,其他用户通过指针总能感知索引结点中的最新内容
    索引结点中增加count计数
    主人删除操作问题:
    删,共享用户访问错误;不删,计费问题。

    符号链
    ②符号链法
    创建一个link类型的文件:“文件名+共享文件路径”(类似快捷方式)
    文件主人删除文件,共享者只会出现找不到文件错误。不会发生共享文件删除后出现悬空指针的情况。
    该方法适用于网络文件共享,但根据路径检索共享文件的目标位置增加了访问开销,link文件独占索引结点也耗费一定的空间。
    无论哪种共享,链接就对应一个文件,如果遍历复制整个目录内的文件,可能会从多条路径对共享文件进行多次访问

    按物理结构划分,文件主要有三类:
    顺序文件、链接文件、索引文件。
    操作系统实现按名存取的关键在于:
    解决文件名与文件存储地址的转换。

    1、文件和文件系统
    文件管理:把所管理的程序和数据组织成一系列的文件,并能进行合理的存储、使用等操作。
    1 )基本概念
    数据项:描述对象某种属性的字符集;是数据组织中可以命名的最小逻辑数据单位。
    记录:一组相关数据项集合,描述对象某方面的属性;
    关键字:一个记录中的一个或几个数据项的集合,用于唯一的标识一个记录。
    文件:由创建者定义的、具有文件名的一组相关元素的集合。
    有结构:由相关记录组成
    无结构:字符流的形式
    属性:类型、长度、物理位置、创建时间

    2 )文件类型
    不同的系统对文件的管理方式不同
    大多用扩展名标志文件类型,按如下几种方式分类文件
    按用途:系统、用户、库文件
    按数据形式:源文件、目标文件、可执行文件
    按存取控制属性:只执行、只读、读写
    按组织和处理方式:普通文件、目录文件、特殊(设备)文件

    3)文件系统模型
    文件目录的管理
    文件共享和保护等
    文件存储空间的管理
    文件逻辑地址转换
    文件读写管理
    四个层次:
    ④逻辑文件系统
    ③基本I/O管理程序
    ②基本文件系统层
    ①I/O控制层

    4)文件操作
    操作系统提供哪些文件操作?
    最基本的操作
    创建/删除文件:分空间,形成FCB及目录(名,地址)
    读、写:按名检索目录,找到文件地址,开始读、写
    设置文件读写位置,实现随机存取(尤其适用于记录文件)

    2、文件的逻辑结构
    文件系统设计的关键要素:
    如何构成一个文件,以及如何存储在外存。
    文件结构:
    文件的逻辑结构file logical structure:按用户观点如何组织数据;又称文件组织file organization
    基本要求:检索速度高、方便修改、降低存储空间费用(不连续)
    文件的物理结构:根据外存上的物理块的分配机制,记录文件外存的存储结构。用户感知不到的。

    1)文件逻辑结构的类型
    有结构文件(记录式)
    ①定长记录
    ②变长记录
    如何组织记录:
    顺序文件。系统需按该类型记录“长度”,通常定长。
    索引文件。系统需为文件建立索引表。
    索引顺序文件。建索引表,记录每组记录的第一个记录位置。
    无结构文件(字符流式)
    字节为单位,利用读写指针依次访问。
    系统对该类文件不需格式处理。
    ①顺序文件
    两种记录排列方式
    串结构:按记录形成的时间顺序串行排序。记录顺序与关键字无关;
    顺序结构:按关键字排序。
    检索方法:
    从头检索,顺序查找要找的记录,定长的计算相对快。
    顺序结构,可用折半查找、插值查找、跳步查找等算法提高效率
    顺序文件的优缺点:
    不方便随机存取某条记录,但适用批量存取的场合。
    适合磁带等特殊介质。
    单记录的查找、修改等交互性差;增减不方便(改进办法:把增删改的记录登记在一个事务文件中,在某段时间间隔后再与原文件合并更新)。
    为了方便单个记录的随机存取,为文件建立一个索引表,记录每项记录在文件的逻辑地址及记录长度;该索引表按关键字排序,。

    4、存储空间的管理
    为实现存储空间分配,系统需要:
    记住空闲存储空间使用情况;为空间设置相应的数据结构;
    提供对存储空间分配、回收的操作手段。
    典型的管理方法:
    1)空闲表法和空闲链表法
    空闲表法
    常用于连续分配管理方式
    数据结构
    系统为外存上的所有空闲区建立一张空闲表
    每个空闲区对应一个空闲表项
    (表项包括序号、空闲区的第一个盘块号、空闲盘块数等。)
    将所有空闲区按其起始盘块号递增的次序排列,如右图。

    2)存储空间的分配与回收操作
    与内存的动态分配类似,同样可采用首次适应算法、循环首次适应算法等。
    回收主要解决对数据结构的数据修改。
    应该说明,虽然很少采用连续分配方式,然而在外存的管理中,由于它具有较高的分配速度,可减少访问磁盘的I/O频率,故它在诸多分配方式中仍占有一席之地。(如实现虚拟用的部分外存就是连续分配方式)

    3)成组链接法
    大型文件系统,空闲表或空闲链表太长不方便管理操作。
    UNIX系统中采用成组链接法,这是将两种方法结合而形成的一种空闲盘块管理方法。
    中心思想:
    所有盘块按规定大小划分为组;
    组间建立链接;
    组内的盘块借助一个系统栈可快速处理,且支持离散分配回收。

  • 相关阅读:
    Nginx资源合并优化模块nginx-http-concat
    Nginx的模块http_secure_link_module
    Nginx前段加速模块pagespeed-ngx
    Naxsi+nginx前段保护
    Selenium for C#的入门Demo
    C# 比较两个数组中的内容是否相同的算法
    C#读取自定义的config
    关于分布式计算之Actor、AKKA和MapReduce
    numpy模块的基本使用
    python单元测试库
  • 原文地址:https://www.cnblogs.com/Kirino1/p/10085016.html
Copyright © 2011-2022 走看看