Linux-文件系统理解(磁盘的物理与逻辑结构、什么是inode、OS如何管理磁盘)

一、磁盘

磁盘的物理结构

        磁盘的本质是一个机械设备,可以存储大量的二进制信息,是实现数据存储的基础硬件设施,磁盘的盘片类似于光盘,不过盘片的两面都是可读可写可擦除的,每个盘面都有一个磁头马达可以使盘片旋转起,磁头悬浮在非常接近盘片表面的位置,通过感应磁性变化来读取或改变磁性以读写数据。

        

        

磁盘的存储结构

        一个磁盘可能拥有多个盘片,一个盘片存在两个盘面,而每个盘面以距离圆心的远近可以分为许多磁道,每个磁道又会被分为许多的扇区,同一径向位置的所有磁道组成一个柱面。

        盘片的旋转是为了定位对应扇区,磁头左右摇摆是为了确定对应的磁道

  1. 盘片(Platters)

    • 硬盘内部包含一组或多组圆形的薄金属盘片,它们堆叠在一起,并且每个盘片表面都涂覆一层磁性材料,用于记录二进制数据。
    • 磁盘片可以双面存储数据,即每个盘片通常会有两个磁化表面。
  2. 磁道(Tracks)

    • 每个盘片表面被划分为一系列同心圆,这些圆轨迹被称为磁道。磁道是记录数据的基本轨道,磁道越靠近中心,其直径越小,容纳的比特密度相对较高。
  3. 扇区(Sectors)

    • 每个磁道进一步被划分为多个扇区,扇区是磁盘上能够独立寻址并存储固定大小数据块的最小单元,常见的扇区大小是512字节或4KB。
  4. 柱面(Cylinders)

    • 同一径向位置的所有磁道组成一个柱面。也就是说,硬盘中所有盘片上相同半径的磁道构成一个柱面。在访问数据时,磁头同时移动到对应柱面上的同一磁道位置。
  5. 磁头(Heads)

    • 每个盘面都有一个读写磁头,它们安装在磁臂(Actuator Arm)上。当磁盘旋转时,磁头悬浮在非常接近盘片表面的位置,通过感应磁性变化来读取或改变磁性以读写数据。

磁盘的逻辑结构

        对于磁带我们知道它是一个线性的存储介质,在录音机中通过磁带在两个圈的旋转便可以访问其中的数据,对于磁盘,我们也可以把他抽象的想象为一个线性的结构,将每个盘面展开,将磁道连接到一起,此时该线性结构就为一个以扇区为基本单位的一个数组,通过数组下标就可以访问对应扇区的内容,只要有扇区对应的下标就可以通过一些简单的计算找到其在磁盘的物理位置。故文件就是在磁盘中占几个扇区的问题

例如:若扇区的下标为index,一个盘面有10个磁道,一个磁道分为了100个扇区,那么一个盘面就拥有1000个扇区,index/1000为该扇区位于哪个盘面,tmp=(index%1000),tmp为该扇位于哥这个盘面的第几个扇区,tmp/100为位于该盘面的哪个磁道,tmp%100为位于该磁道到的第几个扇区。

所以找到一个指定扇区分为三步:

  1. 找到对应的磁头(Header)
  2. 找到对应的磁道(Cylinder)
  3. 找到对应扇区(Sector)

该方法成为CHS定址法

        一个扇区为512个字节,在操作系统与磁盘进行交互的时候,OS认为一次读取512个字节的内容太少了,所以规定与磁盘交互的基本单位为4kb,也就是8个连续的扇区,所以我们可以进一步对磁盘进行抽象,将每8个扇区抽象为一个块,这样磁盘就被抽象为了一个以块为基本单位的数组,称为LBA 逻辑区块地址(块中的8个扇区最后是连续的,不然磁头和盘片要进行大量的旋转寻址,会影响效率),通过块数组下标,我们就可以找到对应扇区的数组下标,n*8就为该块对应第一个扇区的下标,而该块的8个扇区都是连续的,这样就可以锁定该块所有的扇区了。

        所以只要有一个起始,知道磁盘的总大小,该磁盘有多少块,每个块的块号,如何转换到对应的多个CHS地址我们就全部知道了。

        综上所述,一个磁盘被分为了许多的块,操作系统维护这么多的块其实是有一定难度的,一般会对磁盘在进行分区,其实我们的电脑一般就只有一个磁盘,其中的C盘、D盘就是所谓的分区,只要能管理好一个分区就能管理好整个磁盘

二、inode与文件系统

        为了管理好一个分区,OS还会将一个分区进行分组,此时问题就到了如何管理好一个分组?

这样一层一层剥开分析的思想叫做分治。接下来就讲解一下如何管理好一个分组:

文件=内容+属性,文件储存在磁盘的本质就是文件的内容与文件的属性数据保存在磁盘,在Linux下,文件的内容与属性数据是分开保存的

  • Data Blocks:数据区,及保存文件内容的地方,在数据区内抽象存在着许多的块,每个块都有自己的块号,数据就保存在这些快中
  • Block Bitmap:块位图,Block Bitmap中记录着Data Block中哪个数据块已经被占用,哪个数据块没 有被占用
  • inode:文件的类型与内容是不同的,但是描述文件的属性却是相同的,例如文件的大小,文件的创建时间等等,这些数据被保存在一个一个结构体中,这个结构体就称为inode。一般这个结构体的大小是固定的128个字节,每一个文件被一个inode描述,但是inode中并不会保存文件的名字,在内核层面上每一个inode都会有一个inode_number,只要有inode号就可以在inode表中定位一个inode,其中inode中还会存在一个数组:datablock[N],这个数组会保存文件内容保存在Data Blocks中块的下标,通过这个数组就可以找到文件的内容了,总之只要有了inode号就可以找到文件的内容+属性
  • inode Table:inode表就是管理inode的结构,保存着分组内部所有的可用(已经使用 + 没有使用)inode。
  • inode Bitmap: inode位图,每一个比特位表示一个inode是否空闲可用
  • GDT,Group Descriptor Table:块组描述符,描述块组属性信息,记录了当前块inode与块的使用情况等等
  • super block:超级块,super block中保存的是整个分区的使用情况,记录的信息主要有:bolck 和 inode的总量, 未使用的block和inode的数量,一个block和inode的大小,最近一次挂载的时间,最近一次写入数据的 时间,最近一次检验磁盘的时间等其他文件系统的相关信息。Super Block的信息被破坏,可以说整个 文件系统结构就被破坏了
  • 补充:inode的编号是分区级别的,一个分区中的inode不能相同,分区之间的inode可以有重复,每个组都有自己起始的inode编号与结束inode编号,保存在GDT中,而超级块保存着整个分区所有分组的start_inode_num与end_inode_num,这样只要有inode编号,就可以快速定位inode的位置(Data Block也是这样做的)
  • 为什么超级块保存在组中呢,不应该是分区级别的吗?要知道磁盘信息的写入与读取离不了盘片的旋转与磁头的摆动,如果发生了一些意外情况,将分区超级块的信息刮花了,那么这个分区就损坏掉了,其实并不是所有的分组都会保存超级块,一般是隔几个组保存一个,这么做的原因是当一个组中的超级块数据发生错误,可以将其他组超级块正确的内容加载过来,这样提高了磁盘的复用性。
  • 将分区进行分组,并将GDT等文件管理信息写入,这个操作叫做格式化,这样整个分区的文件系统框架就搭建好了

想要得到一个文件的信息,首先需要这个文件的inode编号,我们平常使用的是文件名是怎么获取inode呢?

        首先我们谈一谈目录,目录也是文件,既然是文件就有文件的属性和文件的内容,而目录的内容其实保存的是文件名与inode编号的映射关系,这样我们通过文件名就可以找到该文件的inode编号了,而目录中不允许出现同名文件就是为了避免找到错误的映射关系,并且我们知道在一个目录中想要创建新文件就需要写权限,这是因为新建一个文件需要在所处目中内容中写入文件名与inode的映射关系

        通过上面的讲述我们理解了,想要管理一个文件,只要找到其所在目录下文件名与inode的映射关系就好了,及访问一个文件需要先访问其目录,而目录也是文件,这样就会一层一层的进行逆向路径解析,在Linux下当遇到根目录时就会停止,因为在机器开机时就会导入数据,OS是知道根目录保存在哪里的,这就是为什么我们进行文件操作时必须带文件的路径

inode编号是分区级别的,那怎么判断文件的inode是哪个分区的呢?

        一个分区想要使用,必须与一个目录进行挂载,也就是进入这个分区就相当于进入了这个目录,这样当我们访问一个文件时,只需要对比该文件的路径前缀是与哪个目录相同,然后确定该目录是与哪个分区挂载的,这样就可以找到这个文件的分区了

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

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

相关文章

攻防世界---Web_php_include

1.题目链接 2.补充知识&#xff1a; 3.构造&#xff1a;执行成功 /?pagedata://text/plain,<?php phpinfo()?> 4.构造下面url&#xff0c;得到目录路径 /?pagedata://text/plain,<?php echo $_SERVER[DOCUMENT_ROOT]?> 5构造下面url&#xff0c;读取该路径的…

【网站项目】面向企事业单位的项目申报小程序

&#x1f64a;作者简介&#xff1a;拥有多年开发工作经验&#xff0c;分享技术代码帮助学生学习&#xff0c;独立完成自己的项目或者毕业设计。 代码可以私聊博主获取。&#x1f339;赠送计算机毕业设计600个选题excel文件&#xff0c;帮助大学选题。赠送开题报告模板&#xff…

Node.js、Java、Python、PHP在构建BS系统时的特点比较

在现代软件开发领域&#xff0c;构建一个稳定、高效的B/S&#xff08;浏览器/服务器&#xff09;系统对于企业的信息化发展至关重要。Node.js、Java、Python和PHP是当下流行的几种后端开发技术&#xff0c;它们各自具有独特的特点和优势。本文将对这几种技术在构建B/S系统时的特…

网络编程【InetAddress , TCP 、UDP 、HTTP 案例】

day38上 网络编程 InetAddress 理解&#xff1a;表示主机类 一个域名 对应 多个IP地址 public static void main(String[] args) throws UnknownHostException {//获取本机的IP地址 // InetAddress localHost InetAddress.getLocalHost(); // System.out.println(localHos…

简单认识Git(dirsearch、githack下载),git泄露(ctfhub)

目录 dirsearch下载地址: githack下载&#xff08;一次不成功可多试几次&#xff09; 一、什么是Git 1.git结构 2.git常用命令及示例 3.Git泄露原理 二、Git泄露 1.Log 2.Stash 3.Index 工具准备&#xff1a;dirsearch、githack dirsearch下载地址: GitHub - mauroso…

如何解决微信小程序无法使用css3过度属性transition

由于微信小程序不支持CSS3过度属性transition,所以我们需要利用微信小程序api进行画面过度的展示 首先是官方示例: wxml: <view animation="{{animationData}}" style="background:red;height:100rpx;width:100rpx"></view> js: Page(…

搭建Hive 3.x环境(CentOS 9 + Hadoop3.x)

零、资源准备 虚拟机相关&#xff1a; VMware workstation 16&#xff1a;虚拟机 > vmware_177981.zipCentOS Stream 9&#xff1a;虚拟机 > CentOS-Stream-9-latest-x86_64-dvd1.iso JDK jdk1.8&#xff1a;JDK > jdk-8u261-linux-x64.tar.gz Hadoop Hadoop 3.3.6&a…

【Java】内存可见性问题是什么?

文章目录 内存模型内存可见性解决方案volatile 内存模型 什么是JAVA 内存模型&#xff1f; Java Memory Model (JAVA 内存模型&#xff09;是描述线程之间如何通过内存(memory)来进行交互。 具体说来&#xff0c; JVM中存在一个主存区&#xff08;Main Memory或Java Heap Mem…

架构师系列-搜索引擎ElasticSearch(七)- 集群管理之分片

集群健康检查 Elasticsearch 的集群监控信息中包含了许多的统计数据&#xff0c;其中最为重要的一项就是集群健康&#xff0c;它在 status字段中展示为 green&#xff08;所有主分片和副本分片都正常&#xff09;、yellow&#xff08;所有数据可用&#xff0c;有些副本分片尚未…

Collection与数据结构 二叉树(三):二叉树精选OJ例题(下)

1.二叉树的分层遍历 OJ链接 上面这道题是分层式的层序遍历,每一层有哪些结点都很明确,我们先想一想普通的层序遍历怎么做 /*** 层序遍历* param root*/public void levelOrder1(Node root){Queue<Node> queue new LinkedList<>();queue.offer(root);while (!qu…

Vue 2实现未登录拦截页面功能

在Vue 2中实现未登录拦截页面功能&#xff0c;通常可以通过路由守卫和全局前置守卫来完成。以下是一个基本的实现步骤和示例代码&#xff0c;帮助你创建一个简单的未登录拦截逻辑。 步骤 1: 安装和配置路由 首先&#xff0c;确保你的Vue项目已经安装并配置了vue-router。如果…

Spring Boot(二)— 自定义Spring Boot Starter

在Spring Boot中&#xff0c;自定义Spring Boot Starter是一个常见且强大的功能&#xff0c;它允许开发者为特定的功能或库创建自己的自动配置&#xff0c;从而简化集成过程。 1 前置知识 Spring Boot的事件为应用的启动和关闭提供了详细的上下文信息&#xff0c;使得开发者能…

基于表面势的增强型p-GaN HEMT器件模型

来源&#xff1a;电子学报 22年 摘要 为了满足功率电路及系统设计对p-GaN HEMT&#xff08;High Electron Mobility Transistor&#xff09;器件模型的需求&#xff0c;本文建立了一套基于表面势计算方法的增强型p-GaN HEMT器件SPICE&#xff08;Simulation Program with Int…

Golang | Leetcode Golang题解之第27题移除元素

题目&#xff1a; 题解&#xff1a; func removeElement(nums []int, val int) int {left, right : 0, len(nums)for left < right {if nums[left] val {nums[left] nums[right-1]right--} else {left}}return left }

软件杯 深度学习卷积神经网络垃圾分类系统 - 深度学习 神经网络 图像识别 垃圾分类 算法 小程序

文章目录 0 简介1 背景意义2 数据集3 数据探索4 数据增广(数据集补充)5 垃圾图像分类5.1 迁移学习5.1.1 什么是迁移学习&#xff1f;5.1.2 为什么要迁移学习&#xff1f; 5.2 模型选择5.3 训练环境5.3.1 硬件配置5.3.2 软件配置 5.4 训练过程5.5 模型分类效果(PC端) 6 构建垃圾…

Eland上传bge-large-zh-v1.5向量化模型到ElasticSearch中

最近需要做一些向量检索&#xff0c;试试ES 一、准备 系统&#xff1a;MacOS 14.3.1 ElasticSearch&#xff1a;8.13.2 Kibana&#xff1a;8.13.2 本地单机环境&#xff0c;无集群&#xff0c;也不基于Docker BGE是一个常见的文本转向量的模型&#xff0c;在很多大模型RAG应…

数据仓库—维度建模—维度表设计

维度表 维度表(Dimension Table)是数据仓库中描述业务过程中各种维度信息的表,用于提供上下文和描述性信息,以丰富事实数据的分析 维度表是维度建模的灵魂所在,在维度表设计中碰到的问题(比如维度变化、维度层次、维度一致性、维度整合和拆分等)都会直接关系到维度建模…

docker和kubernetes(k8s)

docker是什么 运行程序需要环境&#xff0c;不同的环境&#xff0c;程序运行的结果就不一样。将程序打包给其它客户端使用时&#xff0c;客户端需要自己配置相应的环境。我们将程序和环境一起打包给其它客户端&#xff0c;客户端可直接运行程序。docker容器作为程序和操作系统…

防汛物资仓库管理系统|实现应急物资仓库三维可视化

系统概述 智慧应急物资仓库可视化系统&#xff08;智物资DW-S300&#xff09;采用了 B/S 架构的设计&#xff0c;通过浏览器即可快速登录操作。实现对库房内的应急物资从申购入库、出库、调拨、库内环境监测、维修保养、检测试验、处置报废等全周期、科学、规范的管理。系统以…

SpringBoot实用开发(十六)-- SpringBoot整合ActiveMQ

目录 1.导入springboot整合ActiveMQ的starter 2.进行yml文件的基础配置 3.使用JmsMessagingTemplate操作ActiveMQ