当前位置: 首页 > news >正文

【Linux系统】分区挂载




在这里插入图片描述



我们能够根据一个 inode 号在指定分区寻找目标文件的 struct inode,也能根据目录文件的内容,通过映射关系,找指定的 inode,可是,现在有个问题:

问题:inode 是不能跨分区使用的!Linux不是可以有多个分区吗?我怎么知道我当前在哪一个分区?

这就涉及到分区挂载问题!

查看系统分区情况

利用命令查询当前系统的分区情况:

命令 ls /dev/vda* :查看当前 Linux 系统中的所有磁盘分区

在这里插入图片描述



命令 df -h:用于显示文件系统的磁盘空间使用情况。

  • 这里的 -h 选项表示以“人类可读”的格式输出信息
  • 显示出系统中每个已挂载的文件系统的总空间、已使用的空间、剩余的空间以及这些文件系统被挂载的位置。

在这里插入图片描述

图中的 tmpfs 是临时文件系统,暂时不用理会

我们只需关心像 /dev/vda3 这样的文件系统分区


你可以看到/dev/vda3 条目中显示 Mounted on 挂载着 / 根目录



到这里可能还不怎么明白,先继续向下看

做个小实验:我们自己创建一个分区!



(1)创建一个大空间文件

命令 dd if=/dev/zero of=./disk.iso bs=1M count=5

  • if=/dev/zero:指定输入文件为 /dev/zero,这是一个特殊的文件,可以无限提供零值的数据。
  • of=./disk.iso:指定输出文件为当前目录下的 disk.iso 文件。
  • bs=1M:设置每次读写操作的数据块大小为 1MB。
  • count=5:指定要复制的数据块数量为 5 个。

整条命令的意思是从 /dev/zero 中读取数据,每次读取 1MB,总共读取 5 次,然后将这些数据写入到名为 disk.iso 的文件中。因此,最终会在当前目录下创建一个大小为 5MB 的全零文件 disk.iso

这种命令常用于创建空的文件或测试文件



不用记住本命令如何写,只要知道该命令最终为我们创建了一个 大小为 5MB 的全零文件!


(2)写入文件系统

向上面的那个新建文件,写入文件系统


命令 mkfs.ext + 双击tab:查询当前Linux系统中支持的文件系统类型

在这里插入图片描述

命令 mkfs.ext4 disk.iso 向文件写 disk.iso 入文件系统 ext4
在这里插入图片描述

到这一步相当于我们有了一个小的分区: disk.iso

但该分区现在还使用不了

还需将这个 “磁盘” 挂载到系统目录下



(3)创建目录

命令 sudo mkdir /mnt/myvda2 :在该目录下创建目录文件 myvda2

意思是准备将我们前面创建的分区挂载到该目录下
在这里插入图片描述



(4)将“虚拟”磁盘分区挂载到目录下

命令 sudo mount -t ext4 ./disk.iso /mnt/myvda2

本条命令的意思是:

mount :挂载
-t ext4 :指明文件系统类型 -t ,为 ext4
./disk.iso /mnt/myvda2 :将分区 ./disk.iso ,挂载到指定路径 /mnt/myvda2

在这里插入图片描述



(5)实验一下

我们 cd 到该文件目录下,即进入该分区内:cd /mnt/myvda2

我们在该目录下创建一个文件,就是在该虚拟磁盘分区中创建

在这里插入图片描述

实际上我们进入的并不是 /mnt/myvda2 ,而是该目录下挂载的虚拟磁盘分区:disk.iso



(6)卸载虚拟分区

命令 sudo umount /mnt/myvda2 :解除挂载

它提示这个卸载目标是忙的,因为当前用户处在这个目录下

在这里插入图片描述

因此需要先退出来再卸载,就能发现消失了
在这里插入图片描述

那我们能不能通过这个方式,卸载掉根目录挂载的磁盘分区呢?

卸载一个路径挂载分区,必须退出该分区所挂载的目录路径

逻辑上做不到卸载掉根目录挂载的磁盘分区,因为我们无论如何都一定处在根目录下,因此这个模块肯定不能通过这个方式卸载


(7)总结


每一个数据分区需要挂载到一个具体的目录下才能被访问和使用。当一个分区被挂载到某个目录后,该目录就成为了该分区的挂载点。从这时起,所有对该挂载点及其子目录的操作实际上都是对这个分区的操作

具体来说,如果你将一个数据分区挂载到了 /mnt/myvda2/ 这个目录下,那么:

  • 你创建的所有文件和目录都将存储在这个分区上。
  • 访问这些文件和目录时,必须通过挂载点 /mnt/myvda2/ 开始指定路径。

例如,如果你在这个分区上创建了一个名为 test1 的目录,然后再在这个目录下创建了一个名为 test2 的子目录,那么这个子目录的完整路径将会是 /mnt/myvda2/test1/test2

  • /mnt/myvda2/ 是挂载点提供的路径部分。
  • test1/test2 是在分区内部创建的路径部分。

这样的设计使得多个不同的物理存储设备可以通过统一的文件系统层次结构(文件系统层次结构是指整个系统的目录树结构)来访问,用户无需关心文件实际存储在哪个物理设备上,只需要通过标准的路径来访问即可。


  1. 根目录(/:整个文件系统层次结构的起点。所有其他的目录和文件都是从根目录开始的。
  2. 挂载点:一个分区或外部存储设备被挂载到现有目录树中的某个特定目录上,这个目录就称为挂载点。挂载点之后的所有文件和目录都属于这个分区。
  3. 统一的命名空间:无论文件实际存储在哪个物理设备上,用户都可以通过一个统一的路径来访问它们。这意味着用户不需要知道文件的具体存储位置,只需知道路径即可。


(8)回答最开始的问题

你怎么确认你在哪一个分区里面???

实际上你在某个挂载了数据分区的目录下,这个目录就是挂载点

所有对该挂载点及其子目录的操作实际上都是对这个分区的操作

只要我们在这个目录下了,其实就已经处于该分区中操作了!

而访问操作一个文件必须通过唯一路径访问,而路径的前缀不就是该数据分区挂载点的路径吗!,不就自动直接进入了该分区中进行操作吗!!!!


我们所有的文件操作都是在根目录的基础下操作的

表示我们就已经进入了挂载到根目录的 /dev/vda3 磁盘分区中,进行操作了!!!

在这里插入图片描述


(9)衍生问题

既然根目录挂载了 /dev/vda3 的磁盘分区

既然在根目录中做的所有操作,实际上都是 /dev/vda3 的磁盘分区中进行的操作,是不是说明我在基于根目录的目录 /mnt/myvda/ 下挂载的一个新数据分区,实际上也存储在/dev/vda3 的磁盘分区中,该数据分区也在 /dev/vda3 的磁盘分区中操作??

并不是的,挂载点具有独立性

当一个目录被挂载到另一个分区时,所有对该目录及其子目录的操作都会在被挂载的分区上进行,而不是在原本的分区上。而挂载点的上级路径仍然在原本的分区中进行操作:

例如:在/mnt/myvda/ 下挂载一个新数据分区,则该目录及其子目录的操作都会在挂载的新数据分区中进行,而挂载点的上级路径仍然在原本的分区中进行(即 /mnt 下的操作还是在原本的分区中)

总结:无论你当前路径属于谁,只要我另外挂载新的分区,则我这个目录就指向新的分区了,独立出去操作了



而我们将分区一挂载到根目录,我们在根目录下又创建几个新目录,用于挂载新分区

不妨碍我们从根目录下开始解析路径,只是解析路径到一个挂载了新分区的目录,则自动进入到这个新分区中继续进行操作,这个解析路径换分区过程实际上是不同目录挂载不同分区,只是跳转到不同的存储分区中继续进行操作罢了



在这里插入图片描述


解析路径的过程

  • 从根目录开始解析
    • 路径从根目录 / 开始。
    • 系统依次查找 /test1, /test2, 和 /test3 目录。
  • 遇到挂载点
    • 发现 /test3 是一个挂载点,挂载了 /dev/vda2 分区。
    • 系统自动跳转到 /dev/vda2 分区中继续解析路径。
  • 在新分区中继续解析
    • /dev/vda2 分区中查找 03.txt 文件。
    • 最终找到并操作 /test3/03.txt 文件。

理论总结

  • 共用同一套文件层次路径:虽然所有的目录和文件共享相同的路径层次结构,但实际存储位置取决于它们所在的分区。
  • 不影响路径指向不同的分区:即使路径看起来相同,由于挂载点的存在,某些路径可能指向不同的物理分区

相关文章:

【Linux系统】分区挂载

我们能够根据一个 inode 号在指定分区寻找目标文件的 struct inode,也能根据目录文件的内容,通过映射关系,找指定的 inode,可是,现在有个问题: 问题:inode 是不能跨分区使用的!Linu…...

Oracle 可观测最佳实践

简介 Oracle 数据库是一种广泛使用的商业关系数据库管理系统(RDBMS),由甲骨文公司(Oracle Corporation)开发。它支持 SQL 语言,能够存储和管理大量数据,并提供高级数据管理功能,如数…...

Ubuntu本地部署网站

目录 1.介绍 2.安装apache 3.网页升级 1.介绍 网站其实就相当于一个文件夹,用域名访问一个网页,就相当于访问了一台电脑的某一个文件夹,在网页中看见的视频,视频和音乐其实就是文件夹里面的文件。为什么网页看起来不像电脑文件夹…...

图数据库 | 18、高可用分布式设计(中)

上文我们聊了在设计高性能、高可用图数据库的时候,从单实例、单节点出发,一般有3种架构演进选项:主备高可用,今天我们具体讲讲分布式共识,以及大规模水平分布式。 主备高可用、分布式共识、大规模水平分布式&#xff…...

Java 读取 Windows 设备的唯一性标识及定位

在 Windows 系统中,获取设备唯一性标识及定位信息对设备管理、安全监控等场景意义重大。本文介绍 Java 中几种实现方法,如 JNA 库、WMI4Java 库及通过 JNI 结合 Windows API。 1. 使用 JNA 库读取 DEVPKEY_Device_ContainerId 在 Windows 系统中&…...

Spring boot框架下的RabbitMQ消息中间件

1. RabbitMQ 基础概念 1.1 消息处理流程与组件配合 Producer(生产者) 发送消息。消息先发送到 Exchange(交换机),而不是直接到队列。Exchange(交换机) 接收到消息后,根据 Routing …...

1 行命令引发的 Go 应用崩溃

一、前言 不久前,阿里云 ARMS 团队、编译器团队、MSE 团队携手合作,共同发布并开源了 Go 语言的编译时自动插桩技术。该技术以其零侵入的特性,为 Go 应用提供了与 Java 监控能力相媲美的解决方案。开发者只需将 go build 替换为新编译命令 o…...

ScratchLLMStepByStep:训练自己的Tokenizer

1. 引言 分词器是每个大语言模型必不可少的组件,但每个大语言模型的分词器几乎都不相同。如果要训练自己的分词器,可以使用huggingface的tokenizers框架,tokenizers包含以下主要组件: Tokenizer: 分词器的核心组件,定…...

G1原理—10.如何优化G1中的FGC

大纲 1.G1的FGC可以优化的点 2.一个bug导致的FGC(Kafka发送重试 subList导致List越来越大) 3.为什么G1的FGC比ParNew CMS要更严重 4.FGC的一些参数及优化思路 1.G1的FGC可以优化的点 (1)FGC的基本原理 (2)遇到FGC应该怎么处理 (3)应该如何操作来规避FGC (4)应该如何操…...

Java基础——概念和常识(语言特点、JVM、JDK、JRE、AOT/JIT等介绍)

我是一个计算机专业研0的学生卡蒙Camel🐫🐫🐫(刚保研) 记录每天学习过程(主要学习Java、python、人工智能),总结知识点(内容来自:自我总结网上借鉴&#xff0…...

2025.1.16——三、supersqli 绕过|堆叠注入|handler查询法|预编译绕过法|修改原查询法

题目来源:攻防世界supersqli 目录 一、打开靶机,整理已知信息 二、sqlmap解题 step 1:爆数据库 step 2:爆表 二、手工注入解题 step 1:判断注入类型 step 2:判断字段数 step 3:查询数据…...

浅谈计算机网络03 | 现代网络组成

现代网络组成 一 、网络生态体系1.1网络生态系统的多元主体1.2 网络接入设施的多样类型 二、现代网络的典型体系结构解析三、高速网络技术3.1 以太网技术3.2 Wi-Fi技术的深度剖析3.2.1 应用场景的多元覆盖3.2.2 标准升级与性能提升 3.3 4G/5G蜂窝网的技术演进3.3.1 蜂窝技术的代…...

Red Hat8:搭建FTP服务器

目录 一、匿名FTP访问 1、新建挂载文件 2、挂载 3、关闭防火墙 4、搭建yum源 5、安装VSFTPD 6、 打开配置文件 7、设置配置文件如下几个参数 8、重启vsftpd服务 9、进入图形化界面配置网络 10、查看IP地址 11、安装ftp服务 12、遇到拒绝连接 13、测试 二、本地…...

EWM 批次管理 / Batch Management

目录 1 简介 2 业务数据 2.1 基于 PO,创建 ERP LE - Delivery 内向交货单,同时同步到 EWM 内向交货单 2.2 在 EWM 内向交货单,创建批次。EWM 批次创建的前提条件来自于物料主数据批次分类(023)。SAP 提供的标准条件…...

Java 面试题 - ArrayList 和 LinkedList 的区别,哪个集合是线程安全的?

Java 面试题 - ArrayList 和 LinkedList 的区别,哪个集合是线程安全的? 在 Java 开发中,ArrayList和LinkedList是两个常用的集合类,它们在数据结构和性能上有诸多不同,同时线程安全性也各有特点。深入理解这些差异&am…...

初学SpringBoot

目录 什么是SpringBoot 使用 Spring Boot有什么好处 Spring Boot 特点 在线构建 IntelliJ IDEA在线模板构建 IntelliJ IDEA 通maven项目构建 SpringBoot的常用配置 入口类和相关注解 定制Banner 修改banner图标 关闭banner 常规属性修改 tomcat端口号修改 常规属性…...

【网络云SRE运维开发】2025第3周-每日【2025/01/15】小测-【第14章ospf高级配置】理论和实操解析

文章目录 14.1 选择题解题思路和参考答案14.2 理论题解题思路和参考答案14.3 实操题解题思路和参考答案思科(Cisco)设备华为(Huawei)设备小米/锐捷(或其他支持标准CLI命令的设备)通过网络管理工具注意事项 …...

AWS S3 跨账户访问 Cross Account Access

进入S3对应的存储桶,上面选项选权限,存储桶策略 -- 编辑,输入对应的policy。 完全控制,包含上传删除权限,policy如下: {"Version": "2012-10-17","Statement": [{"Si…...

Ubuntu20.4和docker终端指令、安装Go环境、安装搜狗输入法、安装WPS2019:保姆级图文详解

目录 前言1、docker、node、curl版本查看终端命令1.1、查看docker版本1.2、查看node.js版本1.3、查看curl版本1.4、Ubuntu安装curl1.5、Ubuntu终端保存命令 2、安装docker-compose、Go语言2.1、安装docker-compose2.2、go语言安装步骤2.3、git版本查看 3、Ubuntu20.4安装搜狗输…...

Kotlin语言的正则表达式

Kotlin语言中的正则表达式 引言 正则表达式(Regular Expression,简称Regex)是一种用于匹配字符串中字符组合的工具。在数据处理、文本解析等领域,正则表达式以其强大的字符串处理能力得到了广泛的应用。而Kotlin作为一种现代的编…...

龙虎榜——20250610

上证指数放量收阴线,个股多数下跌,盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型,指数短线有调整的需求,大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的:御银股份、雄帝科技 驱动…...

CMake基础:构建流程详解

目录 1.CMake构建过程的基本流程 2.CMake构建的具体步骤 2.1.创建构建目录 2.2.使用 CMake 生成构建文件 2.3.编译和构建 2.4.清理构建文件 2.5.重新配置和构建 3.跨平台构建示例 4.工具链与交叉编译 5.CMake构建后的项目结构解析 5.1.CMake构建后的目录结构 5.2.构…...

【单片机期末】单片机系统设计

主要内容:系统状态机,系统时基,系统需求分析,系统构建,系统状态流图 一、题目要求 二、绘制系统状态流图 题目:根据上述描述绘制系统状态流图,注明状态转移条件及方向。 三、利用定时器产生时…...

【服务器压力测试】本地PC电脑作为服务器运行时出现卡顿和资源紧张(Windows/Linux)

要让本地PC电脑作为服务器运行时出现卡顿和资源紧张的情况,可以通过以下几种方式模拟或触发: 1. 增加CPU负载 运行大量计算密集型任务,例如: 使用多线程循环执行复杂计算(如数学运算、加密解密等)。运行图…...

智能AI电话机器人系统的识别能力现状与发展水平

一、引言 随着人工智能技术的飞速发展,AI电话机器人系统已经从简单的自动应答工具演变为具备复杂交互能力的智能助手。这类系统结合了语音识别、自然语言处理、情感计算和机器学习等多项前沿技术,在客户服务、营销推广、信息查询等领域发挥着越来越重要…...

【从零开始学习JVM | 第四篇】类加载器和双亲委派机制(高频面试题)

前言: 双亲委派机制对于面试这块来说非常重要,在实际开发中也是经常遇见需要打破双亲委派的需求,今天我们一起来探索一下什么是双亲委派机制,在此之前我们先介绍一下类的加载器。 目录 ​编辑 前言: 类加载器 1. …...

Scrapy-Redis分布式爬虫架构的可扩展性与容错性增强:基于微服务与容器化的解决方案

在大数据时代,海量数据的采集与处理成为企业和研究机构获取信息的关键环节。Scrapy-Redis作为一种经典的分布式爬虫架构,在处理大规模数据抓取任务时展现出强大的能力。然而,随着业务规模的不断扩大和数据抓取需求的日益复杂,传统…...

uniapp 小程序 学习(一)

利用Hbuilder 创建项目 运行到内置浏览器看效果 下载微信小程序 安装到Hbuilder 下载地址 :开发者工具默认安装 设置服务端口号 在Hbuilder中设置微信小程序 配置 找到运行设置,将微信开发者工具放入到Hbuilder中, 打开后出现 如下 bug 解…...

提升移动端网页调试效率:WebDebugX 与常见工具组合实践

在日常移动端开发中,网页调试始终是一个高频但又极具挑战的环节。尤其在面对 iOS 与 Android 的混合技术栈、各种设备差异化行为时,开发者迫切需要一套高效、可靠且跨平台的调试方案。过去,我们或多或少使用过 Chrome DevTools、Remote Debug…...

GraphQL 实战篇:Apollo Client 配置与缓存

GraphQL 实战篇:Apollo Client 配置与缓存 上一篇:GraphQL 入门篇:基础查询语法 依旧和上一篇的笔记一样,主实操,没啥过多的细节讲解,代码具体在: https://github.com/GoldenaArcher/graphql…...