操作系统16:文件共享和文件保护

news2024/11/24 19:11:48

目录

1、文件共享

(1)基于有向无循环图实现文件共享

1.1 - 有向无循环图 DAG(Directed Acyclic Graph)

1.2 - 利用索引结点

(2)利用符号链接实现文件共享

2、文件保护

(1)保护域(Protection Domain)和访问权

(2)什么是访问矩阵?

2.1 - 基本的访问矩阵

2.2 - 具有域切换权的访问矩阵

(3)如何修改访问矩阵?

3.1 - 拷贝权(Copy Right)

3.2 - 所有权(Owner Right)

3.3 - 控制权(ControlRight)

(4)如何实现访问矩阵?

4.1 - 访问控制表(Access Control List)

4.2 - 访问权限(Capabilities)表


1、文件共享

        在现代计算机系统中,必须提供文件共享手段,即指系统应允许多个用户(进程)共享同一份文件。这样,在系统中只需保留该共享文件的一份副本。如果系统不能提供文件共享功能,就意味着凡是需要该文件的用户,都须各自备有此文件的副本,显然这会造成对存储空间的极大浪费。//文件共享可以节省存储空间,共享文件只需要一个副本

(1)基于有向无循环图实现文件共享

1.1 - 有向无循环图 DAG(Directed Acyclic Graph)

        在严格的树形结构目录中,每个文件只允许有一个父目录,父目录可以有效地拥有该文件,其它用户要想访问它,必须经过其属主目录来访问该文件。这就是说,对文件的共享是不对称的,或者说,树形结构目录是不适合文件共享的//树形结构子节点只允许有一个父节点

        改进:如果允许一个文件可以有多个父目录,即有多个属于不同用户的多个目录,同时指向同一个文件,虽会破坏树的特性,但这些用户可用对称的方式实现文件共享,而不必再通过其属主目录来访问。// 为了文件共享,允许子节点有多个父节点

        下图示出了一个有向无循环图,它允许每一个文件都可以有多个父目录。如图中的文件 F8 有三个父目录,它们分别是 D5、D6 和 D3,其中 D5 和 D3 还使用了相同的名字 p ,目录 D6 有两个父目录 D2 和 D1。

        我们知道,当有多个用户要共享一个子目录或文件时,必须将共享文件或子目录链接到多个用户的父目录中,才能方便地找到该文件。

        现在的问题是,如何建立父目录 D5 与共享文件 F8 之间的链接呢?

        如果在文件目录中所包含的是文件的物理地址,即文件所在盘块的盘块号,则在链接时,必须将文件的物理地址拷贝到 D5 目录中去。但如果以后 D5 或 D6 还要继续向该文件中添加新内容,也必然要相应地再增加新的盘块,这些是由附加操作 Append 来完成的。而这些新增加的盘块也只会出现在执行了操作的目录中// 如果 D5 往文件 F8 中增加了内容,那么新增加的内容只会保存在 D5 中,不会被 D6 和 D3 共享

        可见,这种变化对其他用户而言,是不可见的,因而新增加的这部分内容已不能被共享

1.2 - 利用索引结点

        为了解决新增内容不能被共享问题,可以引用索引结点,即诸如文件的物理地址及其它的文件属性等信息,不再是放在目录项中,而是放在索引结点中。在文件目录中只设置文件名及指向相应索引结点的指针//不再是文件的物理地址

        此时,由任何用户对共享文件所进行的 Append 操作或修改,都将引起其相应结点内容的改变(例如,增加了新的盘块号和文件长度等),这些改变是其他用户可见的,从而也就能提供给其他用户来共享。

// 该方式删除共享文件时,如果没有进行特殊处理,会出现悬空指针,因为共享目录都拥有文件的索引结点

(2)利用符号链接实现文件共享

        利用符号链接实现文件共享的基本思想,同样允许一个文件或子目录有多个父目录,但其中仅有一个作为主(属主)父目录,其它的几个父目录都是通过符号链接方式与之相链接的(简称链接父目录)。

        这样做的最大好处是,属主结构(用实线连接起来的结构)仍然是简单树,这对文件的删除、查找等都更为方便。//保留了文件结构的树结构

        那么,如何利用符号链实现共享呢?

        为使链接父目录 D5 能共享文件 F8,可以由系统创建一个 LINK 类型的新文件,也取名为 F(8),并将 F(8) 写入链接父目录 D5 中,以实现 D5 与文件 F8 的链接。在新文件 F(8) 中只包含被链接文件 F8 的路径名。这样的链接方法被称为符号链接//使用Link文件进行共享

        新文件 F(8) 中的路径名则只被看做是符号链。当用户通过 D5 访问被链接的文件 F8,且正要读 LINK 类新文件时,此要求将被 OS 截获,OS 根据新文件中的路径名去找到文件 F8,然后对它进行读(写),这样就实现了对文件 F8 的共享。//符号链中只有路径名,使用link文件作为载体

        符号链方式的优点:在利用符号链方式实现文件共享时,只是文件主才拥有指向其索引结点的指针;而共享该文件的其他用户则只有该文件的路径名,并不拥有指向其索引结点的指针。这样,也就不会发生在文件主删除一共享文件后留下一悬空指针的情况。当文件的拥有者把一个共享文件删除后,如果其他用户又试图通过符号链去访问一个已被删除的共享文件,则会因系统找不到该文件而使访问失败,于是再将符号链删除,此时不会产生任何影响。//不会产生悬空指针

        符号链方式的问题:读共享文件时,系统根据给定的文件路径名逐个分量(名)地去查找目录,直至找到该文件的索引结点。因此,在每次访问共享文件时,都可能要多次地读盘。这使每次访问文件的开销甚大,且增加了启动磁盘的频率。此外,要为每个共享用户建立一条符号链,而由于链本身实际上是一个文件,尽管该文件非常简单,却仍要为它配置一个索引结点,这也要耗费一定的磁盘空间。//多次读盘+消耗磁盘空间

2、文件保护

        影响文件安全性的主要因素有:

  • 人为因素。人们有意或无意的行为,会使文件系统中的数据遭到破坏或丢失。
  • 系统因素。由于系统的某部分出现异常情况,而造成数据的破坏或丢失,特别是作为数据存储主要介质的磁盘,一旦出现故障,会产生难以估量的影响。
  • 自然因素。随着时间的推移,存放在磁盘上的数据会逐渐消失。

        为了确保文件系统的安全性,可针对上述原因而采取三方面的措施:

  • 通过存取控制机制,防止由人为因素所造成的文件不安全性。
  • 采取系统容错技术,防止系统部分的故障所造成的文件的不安全性。
  • 建立后备系统,防止由自然因素所造成的不安全性。

(1)保护域(Protection Domain)和访问权

        访问权:一个进程能对某对象执行操作的权力,称为访问权(Access right)。每个访问权可以用一个有序对(对象名,权集)来表示,例如,某进程有对文件 F1 执行读和写操作的权力,则可将该进程的访问权表示成(F1,{R/W})

        保护域:“域”是进程对一组对象访问权的集合,进程只能在指定域内执行操作。这样,“域”也就规定了进程所能访问的对象和能执行的操作。// 访问权 -> 保护域

        下图中给出了两个保护域。在域 1 中有两个文件 F1 和 F2,只允许进程对 F1 读,而允许对 F2 读和写;而对象 Printer1 同时出现在域 1 和域 2 中,这表示在这两个域中运行的进程都能使用打印机。

        静态域:在进程和域之间可以一一对应,即一个进程只联系着一个域。这意味着,在进程的整个生命期中,其可用资源是固定的,我们把这种域称为“静态域”。在这种情况下,进程运行的全过程都是受限于同一个域,这将会使赋予进程的访问权超过了实际需要。例如,某进程在运行开始时需要磁带机输入数据,而在进程快结束时,又需要用打印机打印数据。在一个进程只联系着一个域的情况下,则需要在该域中同时设置磁带机和打印机这两个对象,这将超过进程运行的实际需要。//固定保护域

        动态域:在进程和域之间,也可以是一对多的关系,即一个进程可以联系着多个域。在此情况下,可将进程的运行分为若干个阶段,其每个阶段联系着一个域,这样便可根据运行的实际需要来规定在进程运行的每个阶段中所能访问的对象//需要增加保护域切换功能

        这种一对多的联系方式称为动态联系方式,在采用这种方式的系统中,应增设保护域切换功能,以使进程能在不同的运行阶段从一个保护域切换到另一个保护域。

(2)什么是访问矩阵?

2.1 - 基本的访问矩阵

        用来描述系统访问控制的矩阵,称为访问矩阵(AccessMatrix)。访问矩阵中的行代表域列代表对象,矩阵中的每一项是由一组访问权组成的

        访问矩阵中的访问权通常由资源的拥有者或者管理者所决定。当用户创建一个新文件时,创建者便是拥有者,系统在访问矩阵中为新文件增加一列,由用户决定在该列的某个项中应具有哪些访问权,而在另一项中又具有哪些访问权。当用户删除此文件时,系统也要相应地在访问矩阵中将该文件对应的列撤消。

2.2 - 具有域切换权的访问矩阵

        为了实现在进程和域之间的动态联系,需要使进程从一个保护域切换到另一个保护域。//目的

        为了能对进程进行控制,同样应将切换作为一种权力,仅当进程有切换权时,才能进行这种切换。为此,在访问矩阵中又增加了几个对象(切换域)

        例如,在上图中由于域 D1 和 D2 所对应的项目中都有一个 S 即 Switch,故而允许在域 D1 中的进程切换到域 D2 中。类似地,在 D2 域中运行的进程也可以切换到域 D3 中,但不允许该进程再从域 D3 返回到域 D1 或者 D2。// 无Switch,不允许进程切换保护域

(3)如何修改访问矩阵?

3.1 - 拷贝权(Copy Right)

        利用拷贝权可以将在某个域中所拥有的访问权,扩展其它域中。

        在上图中,凡是在访问权上加星号(*)者,都表示在域中运行的进程能将其对象的访问权复制成在任何域中对同一对象的访问权。//加*号,访问权允许复制

        例如,图中在域 D1 中对文件 F3 的写访问权上加有 * 号,表示运行在 D1 域中的进程可以将其对文件 F3 的写访问权扩展到域 D3 中去,类似的,在域 D2 中对文件 F2 的读访问权也是一样。

        应注意的是,把带有 * 号的拷贝权拷贝到新的域以后,其所建立的访问权不再带有 * 号,这使在域 D3 上运行的进程不能再将其拷贝权进行扩散,这种拷贝方式被称为限制拷贝

3.2 - 所有权(Owner Right)

        有时候不仅要求能将已有的访问权进行有控制的扩散,而且同样需要能增加某种访问权,或者能删除某种访问权。此时,可利用所有权(O)来实现这些操作。

        在拥有文件所有权的域中运行的进程,可以删除或新增该文件在其他域中的访问权。//文件的所有者可以对文件的访问权进行各种修改

3.3 - 控制权(ControlRight)

        拷贝权所有权都是用于改变矩阵内同一列的各项访问权的,或者说,是用于改变在不同域中运行的进程对同一对象的访问权的//对一列中的数据进行修改

        控制权则可用于改变矩阵内同一行中(域中)的各项访问权,亦即,用于改变在某个域中运行的进程对不同对象的访问权的。//对一行中的数据进行修改

(4)如何实现访问矩阵?

4.1 - 访问控制表(Access Control List)

        对访问矩阵按列(对象)划分,为每一列建立一张访问控制表 ACL在该表中已把矩阵中属于该列的所有空项删除,此时的访问控制表是由一有序对(域,权集)所组成的。由于在大多数情况下,矩阵中的空项远多于非空项,因而使用访问控制表可以显著地减少所占用的存储空间,并能提高查找速度//按列划分,一个文件一张表

        在不少系统中,当对象是文件时,便把访问控制表存放在该文件的文件控制表中,或放在文件的索引结点中,作为该文件的存取控制信息

        访问控制表也可用于定义缺省的访问权集,即在该表中列出了各个域对某对象的缺省访问权集。在系统中配置了这种表后,当某用户(进程)要访问某资源时,通常是首先由系统到缺省的访问控制表中,去查找该用户(进程)是否具有对指定资源进行访问的权力。如果找不到,再到相应对象的访问控制表中去查找。//缺省访问权限就是默认访问权限

4.2 - 访问权限(Capabilities)表

        如果把访问矩阵按行(即域)划分,便可由每一行构成一张访问权限表。换言之,这是由一个域对每一个对象可以执行的一组操作所构成的表。表中的每一项即为该域对某对象的访问权限。当域为用户(进程)、对象为文件时,访问权限表便可用来描述一个用户对每一个文件所能执行的一组操作。//按行划分,一个域一张表

        目前,大多数系统都同时采用访问控制表访问权限表,在系统中为每个对象配置一张访问控制表。当一个进程第一次试图去访问一个对象时,必须先检查访问控制表,检查进程是否具有对该对象的访问权。如果无权访问,便由系统来拒绝进程的访问,并构成一例外(异常)事件;否则,便允许进程对该对象进行访问,并为该进程建立一访问权限,将之连接到该进程。

        以后,该进程便可直接利用这一返回的权限去访问该对象,这样,便可快速地验证其访问的合法性。当进程不再需要对该对象进行访问时,便可撤消该访问权限。

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

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

相关文章

自动化测试需要学什么【附学习路线和学习教程】

目录 一、接口自动化测试 1、HTTP和HTTPS协议 2、接口文档 3、接口测试工具Jmeter和Postman 5、总结 二、UI自动化测试 1 、Web自动化测试 1.1 Selenium 1.3 总结 2 App自动化测试 2.1 应该选择哪款工具? 三、持续集成 四、总结 随着自动化测试行业的薪…

关于nginx学习记录(二)

系列文章目录 第一章 Nginx 学习入门——Nginx的概述及安装 第二章 Nginx学习入门——Nginx常用命令及nginx.conf配置了解 目录 系列文章目录 一、Nginx 操作常用的命令 二、Nginx 配置文件 1. nginx配置文件位置:/usr/local/nginx/conf 2.nginx.conf配置文件组成: ⑴ 全…

ASL/CS系列音视频转换方案芯片,Typec拓展坞方案芯片

音视频单转方案芯片: CS5565 Typec转HDMI 8K 60HZ转换方案 可替代RTD2173 PS196 CS5801 HDMI转eDP/DP方案 可替代LT6711 CS5212 DP转VGA转换方案 可PIN TO PIN 替代RTD2166 CS5211 E…

Python+Appium自动化测试之元素等待方法与重新封装元素定位方法

目录 一,元素等待方法 1,强制等待 2,隐式等待 3,显式等待 二,重新封装元素定位方法 在appium自动化测试脚本运行的过程中,因为网络不稳定、测试机或模拟器卡顿等原因,有时候会出现页面元素加…

python_day8_综合案例

综合案例,全球GDP排行榜 1、知识点补充:sort()方法 sort()方法: 列表.sort(key选择排序依据的函数,reverseTrue|False) my_list [[a, 33], [b, 55], [c, 11]]def choose_sort_key(element):return element[1] # 列表中每个元素传进来&am…

动态规划01背包之494 目标和(第10道)

题目: 给你一个整数数组 nums 和一个整数 target 。 向数组中的每个整数前添加 或 - ,然后串联起所有整数,可以构造一个 表达式 : 例如,nums [2, 1] ,可以在 2 之前添加 ,在 1 之前添加 -…

C语言知识扫盲

文章目录 1,各种类型所占字节数2,main函数是可以传入参数的3,C语言中extern的用法4,gettop()函数5,C/C中枚举类型enum使用 1,各种类型所占字节数 类型16位32位64位char111short int222int244unsigned int244float444double888long448long long888unsigned long448 …

QUIC协议原理分析

Quic 相比现在广泛应用的 http2tcptls 协议有如下优势 [2]: 减少了 TCP 三次握手及 TLS 握手时间。改进的拥塞控制。避免队头阻塞的多路复用。连接迁移。前向冗余纠错。 队头阻塞 队头阻塞主要是 TCP 协议的可靠性机制引入的。TCP 使用序列号来标识数据的顺序&am…

学C的第二十七天【指针的进阶(三)】

相关代码gitee自取:C语言学习日记: 加油努力 (gitee.com) 接上期: 学C的第二十六天【指针的进阶(二)】_高高的胖子的博客-CSDN博客 复习巩固: 数组名: 数组名是数组首元素的地址, 但是有两个…

数据结构与算法:10种常见算法

前言 本文主要讲解10种常见算法 数据结构与算法文章列表 数据结构与算法文章列表: 点击此处跳转查看 目录 1 二分查找算法 二分查找(Binary Search)是一种在有序数组中查找目标值的常用算法。它通过将目标值与数组中间元素进行比较,可以快…

Cesium被接入数字孪生系统后会产生怎样的改变?

众所周知,Cesium凭借其开源免费的特点一直垄断着整个三维GIS的生态系统,但是随着数字孪生技术的发展以及各项新需求的不断涌现,Cesium与数字孪生系统相结合的潜力也逐渐凸显。 一般而言,Cesium如果想要升级视效就需要去用CesiumF…

基于springboot的智慧养老系统

博主主页:猫头鹰源码 博主简介:Java领域优质创作者、CSDN博客专家、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战 主要内容:毕业设计(Javaweb项目|小程序等)、简历模板、学习资料、面试题库、技术咨询 文末联系获取 项目介绍…

常用的前端可视化Web组态工具

前言 随着创新技术驱动工业物联网不断发展,设备联网所产生的多样化数据,在边缘端与云端进行大数据分析,成为工业应用场景数字化的需求。跨系统可通用,不受硬件限制达成无缝整合,监控组态软件SCADA成为物联网时代建构出…

Unity游戏源码分享-Unity手游火柴忍者游戏StickmanDojo

Unity游戏源码分享-Unity手游火柴忍者游戏StickmanDojo 项目地址:https://download.csdn.net/download/Highning0007/88050234

Windows bat隐藏运行窗口的几种方案

文章目录 一、背景二、测试数据三、隐藏bat运行窗口方案1. 使用VBScript脚本2. 使用mshta调用js或vbs脚本3. 将bat编译为exe程序4. 使用任务计划程序 一、背景 有些程序在执行批处理脚本时,可能会看到dos窗口,或者看到窗口一闪而过。如果批处理脚本执行…

Layui基本功能(增删改查)

话不多说,根据我前面的博客我们直接进行操作。记住以下的文件放置,防止操作出不来. 这是我们要完成的界面及功能 后台功能实现 数据查看 我们在userDao方法里面进行增删改查的方法我们在userAction进行方法的编写R工具类的介绍 查询 userDao方法 因为我…

使用亚马逊(AWS)云服务在S3上实现图片缩放功能(CloudFront/S3[AccessPoint/LambdaAccessPoint])

亚马逊云服务中的S3对象存储功能和国内阿里云的oss对象存储使用基本一致。但是涉及到存储内容处理时,两家有些差别。 比如:对于云存储中的图片资源,阿里云比较人性化对于基本的缩放裁剪功能已经帮我们封装好了,只需要在url地址后…

window环境下安装Node并修改保存缓存的位置

0, 卸载Node 打开cmd命令行窗口 输入: npm cache clean --force然后在控制面版中卸载node 1,官网下载Node.js 点击官网下载 如一台电脑需要多个node环境 可使用nvm命令进行操作安装并且可以切换 2, 配置环境变量 安装成功之后&#x…

竹云参编 |《数据经纪从业人员评价规范》团体标准在2023全球数字经济大会发布

经国务院批准,由北京市人民政府、国家发展和改革委员会、工业和信息化部、商务部、国家互联网信息办公室、中国科学技术协会共同主办的2023全球数字经济大会在中国北京国家会议中心隆重召开。 深圳竹云科技股份有限公司作为主要编制单位,联合深圳数据交…

新大陆物联网云平台-物联网云平台推荐-免费好用的物联网平台

一、前言 作为多年的物联网开发者,使用过很多付费的物联网云平台,包括阿里云、华为云等,也使用过很多免费开源的物联网云平台,但就操作来说,我认为最便利的还是新大陆物联网云平台(NLECloud - 新大陆物联网…