Linux内核之文件系统访问:目录项、inode、物理磁盘访问关系(五十五)

本文主要是介绍Linux内核之文件系统访问:目录项、inode、物理磁盘访问关系(五十五),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

简介: CSDN博客专家,专注Android/Linux系统,分享多mic语音方案、音视频、编解码等技术,与大家一起成长!

优质专栏:Audio工程师进阶系列原创干货持续更新中……】🚀
优质专栏:多媒体系统工程师系列原创干货持续更新中……】🚀
优质视频课程:AAOS车载系统+AOSP14系统攻城狮入门实战课原创干货持续更新中……】🚀

人生格言: 人生从来没有捷径,只有行动才是治疗恐惧和懒惰的唯一良药.

更多原创,欢迎关注:Android系统攻城狮

欢迎关注Android系统攻城狮

🍉🍉🍉文章目录🍉🍉🍉

    • 🌻1.前言
    • 🌻2.Linux文件系统中,目录项(dentry)、inode和物理磁盘之间的关系介绍
      • 🐓2.1 目录项(dentry)
      • 🐓2.1 inode
      • 🐓2.1 物理磁盘
    • 🌻3.问题一:当访问一个test.txt文件时,他们的调用流程发生了什么?
      • 🐓3.1 当访问一个名为 test.txt 的文件时,涉及到以下步骤和调用流程:
    • 🌻4.问题二:详细阐述linux文件系统从应用层到内核层访问test.txt的过程?
      • 🐓4.1 应用层:
      • 🐓4.2 内核层:
      • 🐓4.3 返回应用层:
    • 🌻5.问题三:Binder文件系统中,打开"/dev/binder"设备文件到访问物理磁盘的过程?
      • 🐓5.1 目录项如何找到inode:
      • 🐓5.2 inode如何找到超级块:
      • 🐓5.3 超级块如何找到物理磁盘访问的:

🌻1.前言

本篇目的:Linux内核之目录项/inode/物理磁盘访问关系

🌻2.Linux文件系统中,目录项(dentry)、inode和物理磁盘之间的关系介绍

  • 在Linux文件系统中,目录项(dentry)、inode和物理磁盘之间的关系是理解和文件访问流程的关键。

🐓2.1 目录项(dentry)

目录项是文件系统中的一个概念,它代表了文件系统树中的一个节点。每个目录项都有一个名称和与之关联的inode。目录项的主要作用是提供一个快速查找表,使得内核可以快速地将文件名映射到对应的inode。

🐓2.1 inode

  • inode是文件系统中的一个数据结构,它包含了文件的元数据,如文件大小、创建时间、最后修改时间、权限等。每个inode都有一个唯一的inode号,它是文件系统用来标识文件的唯一标识符。inode还包含了指向文件数据块的指针,这些数据块存储在物理磁盘上。

🐓2.1 物理磁盘

  • 物理磁盘是文件系统中实际存储数据的设备。文件的数据和inode都存储在磁盘上。inode通常存储在磁盘的一个或多个专用区域,而文件数据则存储在数据块中。

🌻3.问题一:当访问一个test.txt文件时,他们的调用流程发生了什么?

🐓3.1 当访问一个名为 test.txt 的文件时,涉及到以下步骤和调用流程:

  • 1.路径名解析: 首先,内核会根据路径名 test.txt 进行路径名解析,将其转换为目录项(dentry)。这个过程涉及到对路径名的拆分,并在文件系统中进行查找,直到找到文件的目录项。
  • 2.目录项查找: 内核根据路径名解析得到的目录项,查找对应的索引节点(inode)。这一步通常涉及文件系统的缓存机制,如果目录项已经被缓存,则可以直接从缓存中获取索引节点指针。
    1. 索引节点访问: 一旦找到了文件的索引节点,内核就可以根据索引节点中的信息,访问文件的元数据信息,如文件类型、文件大小、拥有者等。这些信息可以用于权限检查和其他操作。
  • 4.文件数据读取: 最后,如果是对文件进行读取操作,内核会根据索引节点中的指针信息,从物理磁盘上读取文件的实际数据,并将数据传输到用户空间。
  • 5.整个调用流程涉及了路径名解析、目录项查找、索引节点访问和文件数据读取等步骤,这些步骤是文件系统提供文件访问功能的基础。

🌻4.问题二:详细阐述linux文件系统从应用层到内核层访问test.txt的过程?

  • 从应用层到内核层访问 test.txt 文件的过程:

🐓4.1 应用层:

    1. 打开文件: 应用程序调用 open 系统调用来打开 test.txt 文件。该调用会触发用户空间库函数(如 glibc)中的 open 函数,该函数将文件名转换为系统调用的参数,并将控制权交给内核。
    1. 系统调用: 用户空间的 open 函数通过系统调用界面将请求传递给内核。内核收到系统调用请求后,开始执行相应的系统调用处理程序。

🐓4.2 内核层:

    1. 路径名解析: 内核首先对文件名 test.txt 进行路径名解析,将其拆分成路径名的各个组件,并逐级查找每个组件对应的目录项(dentry)。
    1. 目录项查找: 内核根据路径名解析得到的各个目录项,沿着路径从根目录开始向下查找,直到找到 test.txt 文件对应的目录项。
    1. 索引节点访问: 一旦找到了 test.txt 文件的目录项,内核会获取其关联的索引节点(inode)。索引节点包含了文件的元数据信息,如文件类型、大小、权限等。
    1. 权限检查: 内核会检查应用程序是否具有访问 test.txt 文件的权限。这涉及到对文件的访问权限和用户身份的验证。
    1. 文件描述符分配: 如果权限检查通过,内核会为该打开文件分配一个文件描述符,并创建相应的文件表项(file)。文件描述符是应用程序用来识别已打开文件的唯一标识符。
    1. 文件操作分发: 根据系统调用中指定的操作类型(如读取、写入、关闭等),内核将文件操作分发给相应的文件操作函数(如 readwriteclose)。
    1. 文件数据访问: 对于读取操作,内核会根据文件的索引节点信息,在物理磁盘上找到文件的实际数据,并将数据复制到内核空间的缓冲区中。然后,内核将数据传输到用户空间,以供应用程序使用。
    1. 文件关闭: 当应用程序不再需要访问文件时,它会调用 close 系统调用来关闭文件描述符。内核会释放相应的资源,并关闭文件。

🐓4.3 返回应用层:

    1. 系统调用返回: 内核执行完文件操作后,将结果返回给用户空间的系统调用处理程序。如果操作成功,系统调用返回相应的成功代码;否则,返回错误码。
    1. 应用程序接收结果: 用户空间的库函数(如 glibc)接收到系统调用的返回结果,并将其传递给应用程序。应用程序根据返回结果决定后续的操作。
  • 这是从应用层到内核层访问 test.txt 文件的详细过程。整个过程涉及了路径名解析、权限检查、文件描述符分配、文件操作分发和文件数据访问等多个步骤,以实现对文件的访问和操作。

🌻5.问题三:Binder文件系统中,打开"/dev/binder"设备文件到访问物理磁盘的过程?

  • 在 Binder 文件系统中访问 “/dev/binder” 设备文件时,访问顺序通常是从目录项到inode,再到超级块,最后到物理磁盘。下面详细描述了每个步骤的访问过程:

🐓5.1 目录项如何找到inode:

  • 操作系统首先会从根目录开始,逐级查找目录,直到找到 “/dev” 目录。
  • 在 “/dev” 目录中,系统会查找名为 “binder” 的目录项。一旦找到目标目录项,系统会从中获取到与之关联的inode号码。

🐓5.2 inode如何找到超级块:

  • 一旦找到 “/dev/binder” 目录项中关联的inode号码,操作系统会使用该inode号码来访问文件系统中对应的inode数据结构。
  • 通过该inode数据结构,操作系统可以获取到文件系统的标识信息,如文件系统类型和挂载信息。通常,inode 数据结构中会包含指向文件系统超级块的指针。

🐓5.3 超级块如何找到物理磁盘访问的:

  • 通过 inode 中指向的文件系统超级块,操作系统可以获取文件系统的相关信息,包括文件系统的逻辑结构和元数据信息。
  • 超级块中可能包含有关文件系统布局和数据块索引的信息,这些信息指示了文件系统中数据块的存储位置。
  • 操作系统根据超级块中的信息,通过文件系统的存储管理机制来访问物理磁盘,读取文件系统的数据块和inode数据。
  • 这样的访问顺序确保了文件系统的正常操作和数据的正确访问,从目录项到inode,再到超级块,最后到物理磁盘。

这篇关于Linux内核之文件系统访问:目录项、inode、物理磁盘访问关系(五十五)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/922486

相关文章

Linux使用nload监控网络流量的方法

《Linux使用nload监控网络流量的方法》Linux中的nload命令是一个用于实时监控网络流量的工具,它提供了传入和传出流量的可视化表示,帮助用户一目了然地了解网络活动,本文给大家介绍了Linu... 目录简介安装示例用法基础用法指定网络接口限制显示特定流量类型指定刷新率设置流量速率的显示单位监控多个

ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法

《ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法》本文介绍了Elasticsearch的基本概念,包括文档和字段、索引和映射,还详细描述了如何通过Docker... 目录1、ElasticSearch概念2、ElasticSearch、Kibana和IK分词器部署

Linux流媒体服务器部署流程

《Linux流媒体服务器部署流程》文章详细介绍了流媒体服务器的部署步骤,包括更新系统、安装依赖组件、编译安装Nginx和RTMP模块、配置Nginx和FFmpeg,以及测试流媒体服务器的搭建... 目录流媒体服务器部署部署安装1.更新系统2.安装依赖组件3.解压4.编译安装(添加RTMP和openssl模块

linux下多个硬盘划分到同一挂载点问题

《linux下多个硬盘划分到同一挂载点问题》在Linux系统中,将多个硬盘划分到同一挂载点需要通过逻辑卷管理(LVM)来实现,首先,需要将物理存储设备(如硬盘分区)创建为物理卷,然后,将这些物理卷组成... 目录linux下多个硬盘划分到同一挂载点需要明确的几个概念硬盘插上默认的是非lvm总结Linux下多

linux进程D状态的解决思路分享

《linux进程D状态的解决思路分享》在Linux系统中,进程在内核模式下等待I/O完成时会进入不间断睡眠状态(D状态),这种状态下,进程无法通过普通方式被杀死,本文通过实验模拟了这种状态,并分析了如... 目录1. 问题描述2. 问题分析3. 实验模拟3.1 使用losetup创建一个卷作为pv的磁盘3.

本地搭建DeepSeek-R1、WebUI的完整过程及访问

《本地搭建DeepSeek-R1、WebUI的完整过程及访问》:本文主要介绍本地搭建DeepSeek-R1、WebUI的完整过程及访问的相关资料,DeepSeek-R1是一个开源的人工智能平台,主... 目录背景       搭建准备基础概念搭建过程访问对话测试总结背景       最近几年,人工智能技术

Ollama整合open-webui的步骤及访问

《Ollama整合open-webui的步骤及访问》:本文主要介绍如何通过源码方式安装OpenWebUI,并详细说明了安装步骤、环境要求以及第一次使用时的账号注册和模型选择过程,需要的朋友可以参考... 目录安装环境要求步骤访问选择PjrIUE模型开始对话总结 安装官方安装地址:https://docs.

Linux环境变量&&进程地址空间详解

《Linux环境变量&&进程地址空间详解》本文介绍了Linux环境变量、命令行参数、进程地址空间以及Linux内核进程调度队列的相关知识,环境变量是系统运行环境的参数,命令行参数用于传递给程序的参数,... 目录一、初步认识环境变量1.1常见的环境变量1.2环境变量的基本概念二、命令行参数2.1通过命令编程

Linux之进程状态&&进程优先级详解

《Linux之进程状态&&进程优先级详解》文章介绍了操作系统中进程的状态,包括运行状态、阻塞状态和挂起状态,并详细解释了Linux下进程的具体状态及其管理,此外,文章还讨论了进程的优先级、查看和修改进... 目录一、操作系统的进程状态1.1运行状态1.2阻塞状态1.3挂起二、linux下具体的状态三、进程的

Linux编译器--gcc/g++使用方式

《Linux编译器--gcc/g++使用方式》文章主要介绍了C/C++程序的编译过程,包括预编译、编译、汇编和链接四个阶段,并详细解释了每个阶段的作用和具体操作,同时,还介绍了调试和发布版本的概念... 目录一、预编译指令1.1预处理功能1.2指令1.3问题扩展二、编译(生成汇编)三、汇编(生成二进制机器语