Linux笔记---文件系统硬件部分

1. 文件系统

文件系统是操作系统用于明确存储设备(常见的是磁盘,也有基于NAND Flash的固态硬盘)或分区上的文件的方法和数据结构,即在存储设备上组织文件的方法。

1.1 基本组成

  • 索引节点(inode):用来记录文件的元信息,比如inode编号、文件大小、访问权限、创建时间、修改时间、数据在磁盘的位置等等。索引节点是文件的唯一标识,它们之间一一对应,也同样都会被存储在硬盘中,所以索引节点同样占用磁盘空间。

  • 目录项(dentry):用来记录文件的名字、索引节点指针以及与其他目录项的层级关联关系。多个目录项关联起来,就会形成目录结构,但它与索引节点不同的是,目录项是由内核维护的一个数据结构,不存放于磁盘,而是缓存在内存。

  • 数据块(data block):是文件系统读写的最小单位,用于存储文件的数据。不同的文件系统数据块大小可能不同,例如Linux中的逻辑块大小通常为4KB。

1.2 主要功能

  • 管理和调度文件的存储空间:负责为文件分配和回收磁盘空间,提高磁盘空间的利用率。

  • 提供文件的逻辑结构、物理结构和存储方法:定义了文件在磁盘上的存储方式和组织形式,如链式存储、索引存储等。

  • 实现文件从标识到实际地址的映射:通过索引节点和目录项等数据结构,将用户使用的文件名转换为磁盘上的实际存储地址。

  • 实现文件的控制操作和存取操作:提供对文件的创建、删除、读取、写入等操作的支持。

  • 实现文件信息的共享并提供可靠的文件保密和保护措施:支持多个用户或进程对文件的共享访问,并通过访问权限等机制保护文件的安全性和保密性。

  • 提供文件的安全措施:如文件的加密、备份与恢复等功能,保障文件数据的完整性和可用性。

 这一节,我们主要认识文件系统的硬件部分,即磁盘(或硬盘)。

2. 磁盘

2.1 磁盘的分类

  • 机械硬盘(HDD):机械硬盘是传统的磁盘存储设备,由盘片、磁头、电机、控制电路等部件组成。数据存储在盘片的磁性涂层上,磁头通过在盘片表面移动来读写数据。机械硬盘的优点是容量大、价格相对较低,适合对读写速度要求不高的大容量存储场景。

  • 固态硬盘(SSD):固态硬盘采用闪存芯片作为存储介质,通过电子信号来存储和读取数据,不需要机械部件。固态硬盘的优点是读写速度快、抗震性强、功耗低、噪音小,适合对读写速度要求较高的场景,如系统盘、游戏盘等。

 2.2 机械硬盘的存储结构

磁盘的数据就存储在圆型的磁片上,磁头可以在摇头臂的驱动下,随着盘片的高速旋转,访问到盘片表面的任意位置。

盘片的表面被分为多个存储单元,这些单元被成为扇区。

 扇区:是磁盘存储数据的基本单位,每个扇区可存储512字节。

这意味着,每次对磁盘的数据进行读写都必须将一个扇区的512个字节一起加载到内存中。

通常来说,一块磁盘上有多组盘片与磁头(一个盘片对应两个面、两个磁头)。这些盘片绕着主轴进行同步的高速旋转,磁头在同一个机械臂杆的驱动下进行同步运动。

也就是说这些磁头在竖直方向上连成一条线,指向各自盘面的对应扇区。随着盘片的高速旋转,与磁道一同形成了一个柱面,如图所示。

磁盘容量 = 磁头数 × 磁道(柱面)数 × 每道扇区数 × 每扇区字节数(512)。

2.3 CHS地址定位

操作系统要访问一个文件,就需要知道该文件在哪一个扇区(或哪几个)。

那么,如何定位一个扇区呢?

  1. 定位扇区所在柱面(Cylinder)。
  2. 选择有效磁头(Header)。
  3. 定位扇区(Sector)。

 三个参数 "Cylinder-Header-Sector" 共同构成了 "CHS地址"。

操作系统只要知道所需访问文件对应的 CHS地址 ,即可通过驱动程序完成访问。

CHS模式支持的硬盘容量有限,因为系统用8bit来存储磁头地址,用10bit来存储柱面地址,用6bit来存储扇区地址,而一个扇区共有512Byte,这样使用CHS寻址一块硬盘最大容量为256 * 1024 * 63 * 512B = 8064 MB(1MB = 1048576B)(若按1MB=1000000B来算就是8.4GB)。

2.4 LBA地址定位

我们可以将一个磁道看作一个一维数组,将一个柱面看作二维数组(在同一柱面上的每一个磁道作为二维数组的一行),那么磁盘就可以看作一个三维数组。

我们知道,无论是二维数组还是三维数组,从存储空间上来看都是一维数组首尾相接的结果。

我们按照这样的思路就可以将磁盘的存储空间映射为一维数组。

将这个磁盘抽象成的数组的下标作为扇区的地址,我们就得到了 "LBA地址"(Logical Block Address) ,即线性地址。

同样的,使用 LBA地址,操作系统就能很好的定位到扇区。只要在硬件层面上实现 "LBA地址 到 CHS地址" 的转换。 

2.5 CHS 与 LBA地址的相互转换

CHS 转换为 LBA
LBA = 柱面号C * (磁头数 * 每磁道扇区数) + 磁头号H * 每磁道扇区数 + 扇区号S - 1
  • 扇区通常是从1开始编号的,而柱面和磁道都是从0开始编号的。
  • 在LBA中,地址是从0开始的。
  • 总柱面,磁道个数,扇区总数等信息,在磁盘内部会自动维护,上层开机的时候,会获取到这些参数。
LBA 转换为 CHS
柱⾯号C = LBA / (单个柱⾯的扇区总数 = 磁头数 * 每磁道扇区数)
磁头号H = (LBA % 单个柱⾯的扇区总数) / 每磁道扇区数 
扇区号S = (LBA % 每磁道扇区数) + 1 

从现在开始,我们主要关注LBA 地址,将磁盘看作一个一维数组,而不再关心其底层细节了(交由硬件自动处理)。

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

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

相关文章

AutoSar架构-----XCP模块与协议介绍

1、XCP 模块定义 XCP 一般要求如下图: XCP 导入的类型需要如下表这些头文件: 2、ETAS 工具配置 2.1、XcpGeneral 配置 3、XCP 协议 ASAM-MCD-1MC:ECU 和标定测量系统接口 ASAM-MCD-2MC:即 A2L 文件,是控制器内部信息…

江科大51单片机笔记【10】DS1302时钟可调时钟(下)

写在前言 此为博主自学江科大51单片机(B站)的笔记,方便后续重温知识 在后面的章节中,为了防止篇幅过长和易于查找,我把一个小节分成两部分来发,上章节主要是关于本节课的硬件介绍、电路图、原理图等理论知识…

字节流 InputStream/OutputStream

一、java的I/O java的I/O(输入/输出)流是用于处理数据输入和输出的抽象类。 java的I/O流主要分为两大类,字节流跟字符流。 字节流:用于处理二进制数据,包括InputStream和OutputStream两个主要类及其子类。 字符流:用于处理字符…

使用位运算如何找到数组中只出现一次的数?

题目链接:137. 只出现一次的数字 II - 力扣(LeetCode) 算法解析 位运算是用于二进制的运算符号。而对于多次出现的数字,其二进制都是一模一样的,这里是3次重复的出现是数字。由此我们可以想到,如果我们由低…

最节省服务器,手搓电子证书查询系统

用户预算150元,想要一个最简单证书查询系统。前台能查询证书、后台管理员能登录能修改密码,证书能够手动输入修改删除、批量导入导出删除数据、查询搜索。能够兼容苹果、安卓、PC三端浏览器,最后帮忙部署到云服务器上。 用户预算不多&#xf…

.net 6程序在IIS中部署后点击IIS设置报错“执行此操作时出错”

.net 6写的程序,需要在Windows服务器的IIS中部署,由于是刚装的系统,先安装.net 6运行时,装了才发现没有IIS,于是又通过“添加角色和功能”添加与IIS相关的功能。安装完毕后,在IIS中添加网站,并将…

探针泄露(WEB)

##解题思路 题目提示是探针泄露,未及时删除的探针可能造成严重的数据泄露 探针的文件常见命名为tz.php,访问它 对于php相关参数,我们是可以点击的,点击phpinfo访问 跳转后搜索flag,得到flag

考研复试c语言常见问答题汇总2

11. 关键字和一般标识符有什么不同? C语言中关键字与一般标识符区别: 定义:关键字是C语言预定义的特殊单词(如int、for),有固定含义;标识符是自定义的名称(如变量名、函数名&#xf…

贝壳找房:以 OceanBase 为 JuiceFS 元数据引擎,构建 AI 存储底座

本文作者:王天庆,贝壳计算存储方向容器引擎团队负责人,他专注于云原生技术和AI基础设施的架构设计与实践,在为公司搭建高效、可靠的基础设施的同时,促进了大模型技术在企业内部的快速落地与应用。 导语:随着…

人工智能-周志华ML版|系列习题参考答案与综合测试目录

YI时间|松子茶碎碎念|MM-DFW|LAMBDA系列 星标🌟松子茶 更新不掉队🌟 作者 | 松子茶 © 原创内容(除图片外) 未经作者授权,严禁转载或镜像 机器学习是人工智能领域的核心课程之一。机器学习的基本概念…

OSPF-单区域的配置

一、单区域概念: 单区域OSPF中,整个网络被视为一个区域,区域ID通常为0(骨干区域)。所有的路由器都在这个区域内交换链路状态信息。 补充知识点: OSPF为何需要loopback接口: 1.Loopback接口的…

基于Bert模型的增量微调3-使用csv文件训练

我们使用weibo评价数据,8分类的csv格式数据集。 一、创建数据集合 使用csv格式的数据作为数据集。 1、创建MydataCSV.py from torch.utils.data import Dataset from datasets import load_datasetclass MyDataset(Dataset):#初始化数据集def __init__(self, s…

C语言 —— 此去经年梦浪荡魂音 - 深入理解指针(卷一)

目录 1. 内存和地址 2. 指针变量和地址 2.1 取地址操作符(&) 2.2 指针变量 2.3 解引用操作符 (*) 3. 指针的解引用 3.1 指针 - 整数 3.2 void* 指针 4. const修饰指针 4.1 const修饰变量 4.2 const修饰指针变量 5…

【Linux】线程

文章目录 线程(Thread)1. 什么是线程? 创建线程多线程中的重入问题线程异常线程等待总结 线程(Thread) 1. 什么是线程? 线程是进程中的一个执行单元,它是 CPU 调度的基本单位。线程依赖于进程…

SpringBoot第二天

目录 1.Web开发 1.1简介 1.2SpringBoot对静态资源的映射规则 1.3模板引擎 1.3.1引入thymeleaf; 1.3.2Thymeleaf语法 1.3.2.1标准表达式语法 1.变量表达式 1.3.2.2表达式支持的语法 1.3.2.3常用的thymeleaf标签 1.4Springboot整合springmvc 1.4.1Springmvc…

如何接入DeepSeek布局企业AI系统开发技术

在当今科技飞速发展的时代,人工智能(AI)已成为企业提升竞争力、实现创新突破的关键驱动力。DeepSeek作为一款强大的AI工具,为企业开发自身AI系统提供了有力支持。那么,企业该如何接入DeepSeek进行AI系统开发呢&#xf…

日期累加(注意点)

注意点&#xff1a;①月可能超过12月 ②新年需要重新判断闰年 日期累加 #include <stdio.h>int pd(int year) {return (year % 4 0 && year % 100 ! 0) || (year % 400 0); }int main() {int m;int year, month, day, add;scanf("%d", &m);f…

vue3 前端路由权限控制与字典数据缓存实践(附Demo)

目录 前言1. 基本知识2. Demo3. 实战 前言 &#x1f91f; 找工作&#xff0c;来万码优才&#xff1a;&#x1f449; #小程序://万码优才/r6rqmzDaXpYkJZF 从实战中出发&#xff1a; 1. 基本知识 Vue3 和 Java 通信时如何进行字典数据管理 需要了解字典数据的结构。通常&#…

用于 RGB-D 显著目标检测的点感知交互和 CNN 诱导的细化网络

摘要 通过整合来自RGB图像和深度图的互补信息&#xff0c;能够提升在复杂且具有挑战性场景下的显著性目标检测&#xff08;SOD&#xff09;能力。近年来&#xff0c;卷积神经网络&#xff08;CNNs&#xff09;在特征提取和跨模态交互方面的重要作用已得到充分挖掘&#xff0c;但…

基于SpringBoot的“校园周边美食探索及分享平台”的设计与实现(源码+数据库+文档+PPT)

基于SpringBoot的“校园周边美食探索及分享平台”的设计与实现&#xff08;源码数据库文档PPT) 开发语言&#xff1a;Java 数据库&#xff1a;MySQL 技术&#xff1a;SpringBoot 工具&#xff1a;IDEA/Ecilpse、Navicat、Maven 系统展示 校园周边美食探索及分享平台结构图…