文件系统·linux
目录
磁盘简介
Ext文件系统
块
分区
分组
inode
再谈inode
路径解析
路径缓存
再再看inode
挂载
小知识
磁盘简介
磁盘:一个机械设备,用于储存数据。 未被打开的文件都是存在磁盘上的,被打开的加载到内存中。
扇区:是OS访问磁盘的基本单位,普通为512字节。
磁头:通过左右摆动定位磁道,然后定位扇区
柱面:同一半径上下的磁道构成的柱面
逻辑上看,可以以磁道展开,当做一维数组,以柱面(整个磁盘的同一个垂直位置的磁道为一个柱面)展开,每个柱面都是个二维数组,整个磁盘(多个柱面)就是个三维数组,这样,对于OS来说,只需要在一个三维数组中定位即可对磁盘上的数据进行操作。
所以,对扇区的定位要通过找柱面-》磁道-》扇区的过程,叫CHS地址。
Ext文件系统
块
块:八个扇区组成一个块,块是文件存取的最小单位。
1.OS看待磁盘,认为磁盘是一个块设备,每个块都有下标
2.文件系统看待磁盘,认为磁盘是一个block array[N] 的块设备。
分区
分区:以开始块号和结束块号划分,不同分区其实就是不同的盘,所以一块磁盘就可以通过分区形成C、D等盘。
分组
分组:每个分区被分为多个块组。这里采用分治的思想,分而治之。
在一个块组中
Data Blocks:保存文件的内容,以4KB为单位。大部分的磁盘分区空间,都由Data Blocks占据。(每个数据块(4KB大小的块),都有唯一的编号 )
Block Bitmap(块位图):用来记录Data Blocks 中哪个数据块被占用,哪个数据块没被占用。(每个比特位代表一个数据块,比特位位置表示对应位置的数据块,比特位内容表示是否被占用。 )
inode
1.在文件系统中,文件属性由inode的结构体来描述,而结构体大小是固定的,一般为128字节或256字节。可知,任何文件的属性的种类是相同的,属性的内容不同。
2.为了标识每个文件的唯一性,每个inode中都有inode number(inode编号)。
3.inode结构体中有i_block的数组映射关系表来找到文件内容
所以,上面的块组中的
inode Table:存放文件属性,如文件大小、所有者、最近修改时间等(是当前块组中所有inode属性的集合)。
inode Bitmap:用来标识inode Table中的位置是否被占用。(比特位的位置,表示哪个对应的inode ,比特位的内容表示是否空闲)
GDT:用来描述整个块组的不同分区的位置。
Super Block:管理所有的组,用来描述一个分区分组整体情况。
注:不一定所有的组中都有,但几乎多个组会同时存在同样的Super Block,因为这个部分非常重要,如果损坏会导致整个分区废掉,所以会在多个组中都存在来备份。
所以,新建一个分区时,Super Block和GDT一定有有效数据,要给写入文件系统和分区分组相关的管理信息。
再谈inode
1.inode用来标识文件的唯一性。
2.inode由全分区统一分配(块号也是),不能跨分区,一个分区,就是一个文件系统,相互独立,,每个组的大小固定,每个组有多少个block和inode都是固定的,在Super Block结构中。
3.inode中不存放文件名,为什么呢,因为文件名存放在目录文件的Data Block中,目录文件的Data Block中放的是该目录下的文件的文件名和inode的映射关系。
4.所以,在指定目录下,新建文件,需要就将文件名和inode的映射写入到当前目录的Data Block中,所以要有w权限,读取一个文件的属性,要有r权限,x权限,关系着我们能否打开该目录,打开了才能去读写。
路径解析
要打开一个文件,就要知道这个文件的inode,就要去这个文件的目录文件Date Block中取,但目录文件也是文件,想要打开也要向上找,直到找到根目录,这就是路径解析,总之访问文件都需要其路径。
路径缓存
linux中,当用户访问指定路径下文件(包括路径上目录、最终的文件),linux会在进行路径解析过程中,在内核中形成目录树和路径缓存,加快查找效率。
在内核中使用dentry结构体组织、缓存文件的inode等信息,每个文件都会有对应的dentry结构体,这样访问文件时,会先在dentry树中查找,找到返回inode等数据,没找到再去磁盘中搜索,然后缓存新路径。
dentry树会使用lru算法处理不常访问的路径,防止占内存过多
再再看inode
1.前12个下标直接映射,还有三个分别是一级、二级、三级的间接块指针,一共在inode中只需要存15个指针来指向所有内容块。
2.一级间接块指针指向一个块,这个块中存的不是数据,而是块号,用来映射多个储存数据的块,二级的间接块指针指向一个存着多个一级间接块的块,三级同理,多级映射,就可以让一个inode指向一个很大的文件。
3.一个inode指向的文件如果过大,可以跨组申请块空间。(可能inode用完,block没用完或者反过来,这时,虽然磁盘还有空间,但不能新建文件了)
挂载
指的是将文件系统附加到操作系统的目录树中的某个特定位置(称为挂载点),从而使得该文件系统中的文件和目录能够被访问和使用。
1.一个磁盘必须分区格式化才能使用,一个分区也不能直接使用,需要挂载到指定的目录才可以使用。
2.df -h 查看挂载
3.所以,虽然每个分区inode编号可能重复,但可以根据访问目标文件的“路径前缀”来判断是在哪一个分区。
小知识
1.操作系统通过外设内部的寄存器将数据写给或读出外设。
2.OS一次会读取4KB,就会一次读取32个文件的inode,可以减少IO次数,提高缓存效率。
相关文章:

文件系统·linux
目录 磁盘简介 Ext文件系统 块 分区 分组 inode 再谈inode 路径解析 路径缓存 再再看inode 挂载 小知识 磁盘简介 磁盘:一个机械设备,用于储存数据。 未被打开的文件都是存在磁盘上的,被打开的加载到内存中。 扇区:是…...

【Matlab】雷达图/蛛网图
文章目录 一、简介二、安装三、示例四、所有参数说明 一、简介 雷达图(Radar Chart)又称蛛网图(Spider Chart)是一种常见的多维数据可视化手段,能够直观地对比多个指标并揭示其整体分布特征。 雷达图以中心点为原点&…...
【信息系统项目管理师】第24章:法律法规与标准规范 - 27个经典题目及详解
更多内容请见: 备考信息系统项目管理师-专栏介绍和目录 文章目录 【第1题】【第2题】【第3题】【第4题】【第5题】【第6题】【第7题】【第8题】【第9题】【第10题】【第11题】【第12题】【第13题】【第14题】【第15题】【第16题】【第17题】【第18题】【第19题】【第20题】【第…...

使用JProfiler进行Java应用性能分析
文章目录 一、基本概念 二、Windows系统中JProfiler的安装 1、下载exe文件 2、安装JProfiler 三、JProfiler的破解 四、IDEA中配置JProfiler 1、安装JProfiler插件 2、关联本地磁盘中JProfiler软件的执行文件 3、IDEA中启动JProfiler 五、监控本地主机中的Java应用 …...

遥感解译项目Land-Cover-Semantic-Segmentation-PyTorch之一推理模型
文章目录 效果项目下载项目安装安装步骤1、安装环境2、新建虚拟环境和安装依赖测试模型效果效果 项目下载 项目地址 https://github.com/souvikmajumder26/Land-Cover-Semantic-Segmentation-PyTorch 可以直接通过git下载 git clone https://github.com/souvikmajumder26/Lan…...
最大似然估计(Maximum Likelihood Estimation, MLE)详解
一、定义 最大似然估计 是一种参数估计方法,其核心思想是: 选择能使观测数据出现概率最大的参数值作为估计值。 具体来说,假设数据 D x 1 , x 2 , … , x n D{x_1,x_2,…,x_n} Dx1,x2,…,xn独立且服从某个概率分布 P ( x ∣ θ ) P(…...
【单片机】如何产生负电压?
以下是对知乎文章《单片机中常用的负电压是这样产生的!》的解析与总结,结合电路原理、应用场景及讨论要点展开: 一、负电压产生的核心原理 负电压本质是相对于参考地(GND)的电势差为负值,需通过电源或储能…...
Java 8 Stream 流操作全解析
文章目录 **一、Stream 流简介****二、Stream 流核心操作****1. 创建 Stream****2. 中间操作(Intermediate Operations)****filter(Predicate<T>):过滤数据****1. 简单条件过滤****2. 多条件组合****3. 过滤对象集合****4. 过滤 null 值…...
java线程中断的艺术
文章目录 引言java中的中断何时触发中断阻塞如何响应中断中断的一些实践基于标识取消任务如何处理阻塞式的中断合理的中断策略时刻保留中断的状态超时任务取消的最优解处理系统层面阻塞IO小结参考引言 我们通过并发编程提升了系统的吞吐量,特定场景下我们希望并发的线程能够及…...
【信息系统项目管理师】一文掌握高项常考题型-项目进度类计算
更多内容请见: 备考信息系统项目管理师-专栏介绍和目录 文章目录 一、进度类计算的基本概念1.1 前导图法1.2 箭线图法1.3 时标网络图1.4 确定依赖关系1.5 提前量与滞后量1.6 关键路径法1.7 总浮动时间1.8 自由浮动时间1.9 关键链法1.10 资源优化技术1.11 进度压缩二、基本公式…...
HarmonyOS 鸿蒙应用开发基础:转换整个PDF文档为图片功能
在许多应用场景中,将PDF文档的每一页转换为单独的图片文件是非常有帮助的。这可以用于文档的分享、扫描文档的电子化存档、或者进行进一步的文字识别处理等。本文将介绍如何使用华为HarmonyOS提供的PDF处理服务将整个PDF文档转换为图片,并将这些图片存放…...
Flask-SQLAlchemy核心概念:模型类与数据库表、类属性与表字段、外键与关系映射
前置阅读,关于Flask-SQLAlchemy支持哪些数据库及基本配置,链接:Flask-SQLAlchemy_数据库配置 摘要 本文以一段典型的 SQLAlchemy 代码示例为引入,阐述以下核心概念: 模型类(Model Class) ↔ 数…...
刷题 | 牛客 - js中等题-下(更ing)30/54知识点解答
知识点汇总: 数组: Array.prototype.pop():从数组末尾删除一个元素,并返回这个元素。 Array.prototype.shift():从数组开头删除一个元素,并返回这个元素。 array.reverse():将数组元素反转顺…...
RAM(随机存取存储器)的通俗解释及其在路由器中的作用
RAM(随机存取存储器)的通俗解释及其在路由器中的作用 一、RAM是什么? RAM(Random Access Memory) 就像餐厅的“临时工作台”: 核心作用:临时存储正在处理的任务(如厨师同时处理多道…...

六、【前端启航篇】Vue3 项目初始化与基础布局:搭建美观易用的管理界面骨架
【前端启航篇】Vue3 项目初始化与基础布局:搭建美观易用的管理界面骨架 前言技术选型回顾与准备准备工作第一步:进入前端项目并安装 Element Plus第二步:在 Vue3 项目中引入并配置 Element Plus第三步:设计基础页面布局组件第四步…...
【项目需求分析文档】:在线音乐播放器(Online-Music)
1. 用户管理模块 1.1 注册功能 功能描述 提供注册页面,包含用户名、密码输入框及提交按钮。用户名需唯一性校验,密码使用 BCrypt 加密算法存储。注册成功后自动跳转至登录页面。 1.2 登录功能 功能描述 提供登录页面,包含用户名、密码输入…...

C++ 前缀和数组
一. 一维数组前缀和 1.1. 定义 前缀和算法通过预处理数组,计算从起始位置到每个位置的和,生成一个新的数组(前缀和数组)。利用该数组,可以快速计算任意区间的和,快速求出数组中某一段连续区间的和。 1.2. …...
PHP 实现通用数组字段过滤函数:灵活去除或保留指定 Key
PHP 实现数组去除或保留指定字段的通用函数详解 一、文章标题 《PHP 实现通用数组字段过滤函数:灵活去除或保留指定 Key》 二、摘要 在实际开发中,我们经常需要对数组进行字段级别的操作,例如从一个数组中删除某些敏感字段(如密码、token),或者只保留特定字段用于接口…...
NACOS2.3.0开启鉴权登录
环境 名称版本nacos2.3.0(Linux)java java version "17.0.14" 2025-01-21 LTS # # Copyright 1999-2021 Alibaba Group Holding Ltd. # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use thi…...

细胞冻存的注意事项,细胞冻存试剂有哪些品牌推荐
细胞冻存的原理 细胞冻存的基本原理是利用低温环境抑制细胞的新陈代谢,使细胞进入一种“休眠”状态。在低温条件下,细胞的生物活动几乎停止,从而实现长期保存。然而,细胞在冷冻过程中可能会因为细胞内外水分结冰形成冰晶而受损。…...

快速上手Linux火墙管理
实验网络环境: 主机IP网络f1192.168.42.129/24NATf2(双网卡) 192.168.42.128/24 192.168.127.20/24 NAT HOST-NOLY f3192.168.127.30/24HOST-ONLY 一、iptables服务 1.启用iptables服务 2.语法格式及常用参数 语法格式:参数&…...

[创业之路-375]:企业战略管理案例分析 - 华为科技巨擘的崛起:重构全球数字化底座的超级生命体
在人类文明从工业时代(机械、电气、自动化)迈向数字智能(硬件、软件、算法、虚拟、智能)时代的临界点上,一家中国企业正以令人震撼的姿态重塑全球科技版图。从通信网络的底层架构到智能终端的生态闭环,从芯…...
【paddle】常见的数学运算
根据提供的 PaddlePaddle 函数列表,我们可以将它们按照数学运算、逻辑运算、三角函数、特殊函数、统计函数、张量操作和其他操作等类型进行分类。以下是根据函数功能进行的分类: 取整运算 Rounding functions 代码描述round(x)距离 x 最近的整数floor(…...

AI基础知识(05):模型提示词、核心设计、高阶应用、效果增强
目录 一、核心设计原则 二、高阶应用场景 三、突破性技巧 以下是针对DeepSeek模型的提示词设计思路及典型应用场景示例,帮助挖掘其潜在能力: 一、核心设计原则 1. 需求明确化:用「角色定位任务目标输出格式」明确边界 例:作为历…...
分布式事务之Seata
概述 Seata有四种模式 AT模式:无侵入式的分布式事务解决方案,适合不希望对业务进行改造的场景,但由于需要添加全局事务锁,对影响高并发系统的性能。该模式主要关注多DB访问的数据一致性,也包括多服务下的多DB数据访问…...

推测解码算法在 MTT GPU 的应用实践
前言 目前主流的大模型自回归解码每一步都只生成一个token, 尽管kv cache等技术可以提升解码的效率,但是单个样本的解码速度依然受限于访存瓶颈,即模型需要频繁从内存中读取和写入数据,此时GPU的利用率有限。为了解决这种问题,…...

Axure酒店管理系统原型
酒店管理系统通常被设计为包含多个模块或界面,以支持酒店运营的不同方面和参与者。其中,管理端和商户端是两个核心组成部分,它们各自承担着不同的职责和功能。 软件版本:Axure RP 9 预览地址:https://556i1e.axshare.…...

写实交互数字人在AI招聘中的应用方案
随着科技的进步,越来越多的行业开始探索如何利用人工智能提升效率和服务质量。其中,写实交互数字人技术以其高度拟真的交互体验和丰富的情感表达能力,在人力资源领域特别是招聘环节中展现出了巨大潜力。本文将探讨写实交互数字人在AI招聘中的…...
C++中IO类(iostream、fstream和sstream)知识详解和应用
一、C I/O 类体系概览 C 的 I/O 功能由一组 流(stream) 类封装,位于头文件 <iostream>、<fstream>、<sstream> 等。核心类别及其继承关系简图如下: ios_base↑basic_ios<CharT,Traits>↑┌───────…...
Spring Boot中如何对密码等敏感信息进行脱敏处理
以下是常见的脱敏方法及实现步骤,涵盖配置、日志和API响应等多个层面: 1. 配置文件敏感信息脱敏 (1) 使用加密库(如Jasypt) 步骤: 添加依赖: <dependency><groupId>com.github.ulise…...