Linux 文件系统

2023-05-16

Linux 文件系统以及常见命令

  • Linux 文件系统
    • block 与 inode
    • 文件类型
    • 权限
    • 目录树
    • 挂载
  • 管道
    • 啥是管道
    • 管道的分类
    • 管道的实质

Linux 文件系统

在 Linux 中一切皆文件,不仅仅是平时所使用的 txt、pdf 等常见的文件,连 Linux 中的命令 cd、ifconfig 等也是以文件形式储存,网络接口卡、磁盘驱动器、打印机、输入输出设备等花里胡哨的东西也是文件

block 与 inode

既然一切都是文件,那这些文件应该存放在哪呢

我们先来了解计算机硬件的相关概念,磁盘中存放数据的最小也是基本单位是一个叫扇区的东西(Sector),每个扇区存储 512 字节

磁盘上的每个磁道被等分为若干个弧段,这些弧段便是磁盘的扇区

在这里插入图片描述
为了对扇区进行查找和管理,需要对扇区进行编号,扇区的编号从0磁道开始,起始扇区为1扇区,其后为2扇区、3扇区……,0磁道的扇区编号结束后,1磁道的起始扇区累计编号,直到最后一个磁道的最后一个扇区(n扇区)。例如,某个硬盘有1024个磁道,每个磁道划分为63个扇区,则0磁道的扇区号为1~63,1磁道的起始扇区号为64最后一个磁道的最后一个扇区号为64512

块(block)由多个扇区组成。文件数据存储在块中。块的最常见的大小是 4kb,约为 8 个连续的扇区组成。一个文件可能会占用多个 block,但是一个块只能存放一个文件

我们需要一个空间来存储文件的元信息:如某个文件被分成几块、每一块在的地址、文件拥有者,创建时间,权限,大小等。这种存储文件元信息的区域就叫inode。 每个文件都有一个inode,存储文件的元信息

操作系统自动将硬盘分成两个区域。一个是数据区,存放文件数据;另一个是inode区,存放inode所包含的信息

可以使用stat命令可以查看文件的inode信息

文件:vimrc
大小:1982      	块:8          IO 块:4096   普通文件
设备:fd00h/64768d	Inode:18069724    硬链接:1
权限:(0644/-rw-r--r--)  Uid:(    0/    root)   Gid:(    0/    root)
环境:system_u:object_r:etc_t:s0
最近访问:2022-07-27 09:40:38.884022629 +0800
最近更改:2022-06-27 21:47:04.000000000 +0800
最近改动:2022-07-27 09:24:57.405008730 +0800
创建时间:2022-07-27 09:24:57.405008730 +0800

文件类型

在 Linux 中第一个字符代表这个文件是目录、文件或链接文件等等

普通文件:当为 - 则是文件,用于存储信息和数据, Linux用户可以根据访问权限对普通文件进行查看、更改和删除。比如:图片、声音、PDF、text、视频、源代码等等。

目录文件:当为 d 则是目录,目录也是文件的一种,用于表示和管理系统中的文件,目录文件中包含一些文件名和指向这些文件的指针。打开目录事实上就是打开目录文件

硬链接:多个文件名指向同一索引节点是存在的。一般这种连接就是硬连接。硬连接的作用是允许一个文件拥有多个有效路径名,这样用户就可以建立硬连接到重要文件,以防止“误删”的功能。而文件真正删除的条件是与之相关的所有硬连接文件均被删除。

符号链接文件(软链接):保留了指向文件的地址,而不是文件本身。实际上是一个文本文件

管道文件:一种特殊类型的文件,用于进程之间的通信。

套接字:用于进程间的网络通信,也可以用于本机之间的非网络通信。

权限

Linux 系统是一个多用户多任务的分时操作系统,任何一个要使用系统资源的用户,都必须首先向系统管理员申请一个账号,然后以这个账号的身份进入系统

每个用户都有一个用户组,系统可以对一个用户组中的所有用户进行集中管理。不同 Linux 系统对用户组的规定有所不同,如 Linux 下的用户属于与它同名的用户组,这个用户组在创建用户时同时创建

完成用户管理的工作有许多种方法,但是每一种方法实际上都是对有关的系统文件进行修改。

与用户和用户组相关的信息都存放在一些系统文件中,这些文件包括 /etc/passwd, /etc/shadow,,/etc/group 等

在使用 ll 等命令查看文件的时候就会显示该文件对应的权限
在这里插入图片描述
有时会用1表示 r 权限,2表示 w 权限,4表示 x 权限,因此像是所有用户可读可写可执行就可以写为777,只需要9个 bit 就可以存放这些权限了

超级用户可以无视普通用户的权限,即使文件目录权限是 000,依旧可以访问

文件的所有者一般为文件的创建者,谁创建了该文件,就天然的成为该文件的所有者,用 ls ‐ahl 命令可以看到文件的所有者,也可以使用 chown 用户名 文件名来修改文件的所有者(chown 命令用于修改文件权限)

当某个用户创建了一个文件后,这个文件的所在组就是该用户所在的组用 ls ‐ahl命令可以看到文件的所有组也可以使用 chgrp 组名 文件名来修改文件所在的组

目录树

Liunx 不像 win,有C盘D盘,它只有一个目录树/,当然这个/也是个文件

所有可操作的计算机资源都存在于目录树这个结构中,对计算资源的访问,可以看做是对这棵目录树的访问,目录如下:
在这里插入图片描述
每个目录的意义:

/bin: 存放二进制可执行文件(ls、cat、mkdir 等),常用命令一般都放在这里
/etc: 存放系统管理和配置文件,比如 hosts 等;
/home: 存放所有用户文件的根目录,是用户主目录的基点,比如用户 user 的主目录就是 /home/user,可以用~user 表示,当前用户输入 ~ 即可回到自己的文件夹
/root: 超级用户(系统管理员)的主目录
/lib:lib 是 Library(库) 的缩写这个目录里存放着系统最基本的动态连接共享库,其作用类似于 Windows 里的 DLL 文件。几乎所有的应用程序都需要用到这些共享库
/opt:opt 是 optional(可选) 的缩写,这是给主机额外安装软件所摆放的目录。比如你安装一个 ORACLE 数据库,或者 tomcat 则就可以放到这个目录下。默认是空的
/usr:usr 是 unix shared resources(共享资源) 的缩写,这是一个非常重要的目录,这里面存放可分享的与不可变动的文件,系统在安装的时候就会将一些默认的软件安到这里面
/sbin:存放开机时需要用到的命令
/dev:一般来说 dev 是开发的意思,这个命令下挂载了很多硬件资源,任何装置与接口设备都是以文件的型态存在于这个目录当中的
/srv:是 server 的简写,存放了各种服务所需要的资源,比如可以在这下面的 www 文件夹下存放一些服务器所需要的 pdf 等文件
/media:媒体,用来存放(挂载)接入的临时文件,默认情况下 Linux 的外部接入的资源都会存放到这个目录下,比如软盘、光盘、DVD 等
/tmp:类似 media,都是存放临时文件的地方,让一般使用者或者是正在执行的程序暂时放置文件的地方

其他的目录在需要查找文件的时候去百度就可以了

挂载

所谓的挂载就是利用一个目录当成进入点,将磁盘分区槽的数据放置在该目录下; 也就是说,进入该目录就可以读取该分割槽的意思。这个动作我们称为挂载,那个进入点的目录我们称为挂载点

当在 Linux 系统中使用这些设备资源时,只有将 Linux 本身的文件目录与磁盘文件以及硬件设备的文件目录合二为一,硬件设备才能为我们所用。合二为一的过程称为“挂载”

如果不挂载,通过Linux系统中的图形界面系统可以查看找到硬件设备,但命令行方式无法找到

挂载,指的就是将设备文件中的顶级目录连接到 Linux 根目录下的某一目录(最好是空目录),访问此目录就等同于访问设备文件

将设备文件抽象一下,一些网络资源也可以用来挂载到 Linux 中的某一目录下

管道

啥是管道

管道是Linux中一种进程通信方式,对应四大通信方式的管道通信系统

管道文件是建立在内存之上可以同时被两个进程访问的文件,管道里存放的数据先进先出,管道里数据在内存中

管道的分类

管道一般分为两种,无名管道和有名管道

使用 mkfifo 函数创建有名管道,它提供了一个路径名与之关联,以有名管道的文件形式存在于文件系统中,两个进程只要可以访问该路径,就能够彼此通过有名管道相互通信

另外一个叫无名管道,有名管道可以在任意两个进程之间通讯,而无名管道只能在父子进程之间通迅;同时,无名管道单独构成一种文件系统,并且只存在与内存中

管道是半双工的,数据只能向一个方向流动,双方通信时,需要建立起两个管道

管道的实质

管道的实质是一个内核缓冲区,进程以先进先出的方式从缓冲区存取数据,管道一端的进程顺序的将数据写入缓冲区,另一端的进程则顺序的读出数据

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Linux 文件系统 的相关文章

  • 内核驱动程序从用户空间读取正常,但写回始终为 0

    因此 我正在努力完成内核驱动程序编程 目前我正在尝试在应用程序和内核驱动程序之间构建简单的数据传输 我使用简单的字符设备作为这两者之间的链接 并且我已成功将数据传输到驱动程序 但我无法将有意义的数据返回到用户空间 内核驱动程序如下所示 in
  • linux新手关于嵌入式linux设备驱动的问题

    最近在研究linux驱动 正如我读过的那些文章所说 设备驱动程序模块很可能会根据内核的需要自动加载 因此我想知道内核如何确定为特定设备 声卡 I2C spi 设备 等 我也无法彻底想象内核如何在启动时检测每个硬件设备 与嵌入式linux相关
  • 找出Linux上一个进程使用了​​多少内存页

    我需要找出进程分配了多少内存页 每个页面是 4096 进程内存使用情况我在查找正确值时遇到一些问题 当我查看 gome system monitor 时 内存映射下有几个值可供选择 Thanks 这样做的目的是将内存使用量除以页数并验证页大
  • 我们如何在使用循环时调用 ansible playbook 中的变量

    我有两个文件 其中这些文件包含server names and server IP s 我想更改 替换一些特定的server names and IP addressees根据要求在两个文件中 这与这篇文章 因为它被要求开设一个新职位 ht
  • 段错误...关于你好世界

    这段代码非常简单 但我在 x86 64 Linux 系统上遇到了段错误 这让我很烦恼 刚开始接触asm 请耐心等待 与 NASM 组装nasm f elf64 test asm 与连接ld o test test o SECTION tex
  • 任何退出 bash 脚本但不退出终端的方法

    当我使用exitshell 脚本中的命令 该脚本将终止终端 提示符 有什么方法可以终止脚本然后停留在终端中吗 我的剧本run sh预计通过直接获取或从另一个脚本获取来执行 编辑 更具体地说 有两个脚本run2 sh as run sh ec
  • 如何获取与 shell 中的文件名模式匹配的所有文件的总文件大小?

    我正在尝试仅使用 shell 来计算与文件名模式匹配的所有文件 在目录树中 的总大小 以字节为单位 这是我到目前为止所拥有的 find name undo exec stat c s awk 总计 1 END 打印总计 有没有更简单的方法来
  • 如何在C(Linux utf8终端)中打印“盒子抽屉”Unicode字符?

    我正在尝试显示 方框图范围 2500 257F 中的 Unicode 字符 它应该是标准 utf8 Unicode 标准 版本 6 2 我根本做不到 我首先尝试使用旧的 ASCII 字符 但 Linux 终端以 utf8 显示 并且没有显示
  • 在 scapy 中通过物理环回发送数据包

    我最近发现了 Scapy 它看起来很棒 我正在尝试查看 NIC 上物理环回模块 存根上的简单流量 但是 Scapy sniff 没有给出任何结果 我正在做的发送数据包是 payload data 10 snf sniff filter ic
  • 使用 ioctl 在 C++ 中以编程方式添加路由

    我编写了简单的 C 函数 添加了新路线 void addRoute int fd socket PF INET SOCK DGRAM IPPROTO IP struct rtentry route memset route 0 sizeof
  • 更新Linux中的包含路径

    我的 my path to file 文件夹中有几个头文件 我知道如何将这些文件包含在新的 C 程序中 但每次我都需要在包含它之前输入头文件的完整路径 我可以在linux中设置一些路径变量 以便它自动查找头文件吗 您可以创建一个 makef
  • 链接错误:命令行中缺少 DSO

    我对 Linux 使用 Ubuntu 14 04 LTS 64 位 相当陌生 来自 Windows 并且正在尝试移植我现有的 CUDA 项目 当通过链接时 usr local cuda bin nvcc arch compute 30 co
  • Linux shell 从用户输入中获取设备 ID

    我正在为一个程序编写安装脚本 该程序需要在其配置中使用 lsusb 的设备 ID 因此我正在考虑执行以下操作 usblist lsusb put the list into a array for each line use the arr
  • Crontab 每 5 分钟一次 [关闭]

    Closed 这个问题是无关 help closed questions 目前不接受答案 我如何告诉 crontab 每 5 分钟运行一次 但从每小时的第二分钟开始 换句话说 我想在以下时间执行我的脚本minute 5 2 例如 我的脚本应
  • 来自守护程序的错误响应:加入会话密钥环:创建会话密钥:超出磁盘配额

    我尝试在我的服务器上安装 docker 使用本教程 https docs docker com install linux docker ce ubuntu 我想远程运行 docker 镜像并使用 portainer Web 界面来管理一切
  • 在汇编中使用 printf 会导致管道传输时输出为空,但可以在终端上使用

    无输出 https stackoverflow com questions 54507957 printf call from assembly do not print to stdout即使在终端上 当输出不包含换行符时也有相同的原因
  • Linux 使用 boost asio 拒绝套接字绑定权限

    我在绑定套接字时遇到问题 并且以用户身份运行程序时权限被拒绝 这行代码会产生错误 acceptor new boost asio ip tcp acceptor io boost asio ip tcp endpoint boost asi
  • ssh 连接超时

    我无法在 git 中 ssh 到 github bitbucket 或 gitlab 我通常会收到以下错误消息 如何避免它 输出 ssh T email protected cdn cgi l email protection i ssh
  • ioctl 命令的用户权限检查

    我正在实现 char 驱动程序 Linux 并且我的驱动程序中有某些 IOCTL 命令仅需要由 ADMIN 执行 我的问题是如何在 ioctl 命令实现下检查用户权限并限制非特权用户访问 IOCTL 您可以使用bool capable in
  • 仅使用containerd(不使用Docker)修剪容器镜像

    如果我刚刚containerd安装在 Linux 系统上 即 Docker 是not安装 如何删除未使用的容器映像以节省磁盘空间 Docker 就是这么方便docker system prune https docs docker com

随机推荐

  • proxmox从6.0升级到6.3

    作者 xff1a 吴业亮 博客 xff1a wuyeliang blog csdn net 删除企业源 rm rf etc apt sources list d pve enterprise list 下载秘钥 wget http mirr
  • ubuntu下qt安装以及环境搭建

    1 下载https download qt io archive qt 2 chmod 43 x qt opensource linux x64 5 14 2 run 3 sudo qt opensource linux x64 5 14
  • ProxmoxVE 之集群安装&ceph集成(引用不加图)

    上次找了一台物理服务器直接安装了一个proxmox VE 环境 xff08 VE是虚拟化环境的意思 xff09 xff0c 后续又看了官方的admin文档 xff0c 对整个系统架构有了一定的了解 xff0c 接下来 xff0c 准备好好研
  • ubuntu安装配置squid进行代理

    前段时间 xff0c 在ubuntu下安装了squid xff0c 进行代理测试 xff0c 现将方法记录如下 xff1a 一 实验环境 两台虚拟机 xff0c 一台为ubuntu xff0c 一台为windows xp 其中 xff0c
  • dos中的变量

    1 0 9 用于获取命令行的参数 2 i用在命令行中的for语句 3 i用在脚本文件中的for语句 4 var 立即扩展变量var的值 5 xff01 var xff01 延迟扩展变量的值 xff08 提前设置 setlocal enabl
  • IDEA实用插件之Spring Assistant——可视化构建SpringBoot项目(社区版专用)

    应用场景 社区版的idea中无法创建spring boot应用 xff0c 旗舰版不存在这方面的问题 社区版要实现创建SpringBoot项目 xff0c 一个途径是通过Spring的官网 xff0c 网页版的spring initiali
  • vue-element-plus-admin整合后端实战——实现系统登录、缓存用户数据、实现动态路由

    目标 整合vue element plus admin前端框架 xff0c 作为开发平台的前端 准备工作 前端选用vue element plus admin xff0c 地址 https gitee com kailong11012013
  • linux下 有线和无线同时工作

    又要使用公司内网收邮件 xff0c 又要使用wifi上外网 为了这个问题 xff0c 百度了下 xff0c 都是抄来抄去的文章 xff0c 好烦 解决方法 xff0c 就是使用route命令 xff0c 修改静态路由表 方法 xff1a 1
  • MySQL监控告警及可视化:Zabbix+Percona PMP实现(Part II)

    MySQL监控告警及可视化 xff1a Zabbix 43 Percona PMP实现 xff08 Part II xff09 PMP插件安装PMP监控脚本配置Web界面导入PMP模板 服务器清单如下 xff1a 服务器IP配置OS版本服务
  • 引用远程资源库中不存在的jar包,相关问题及解决方案

    问题背景 项目中需要用到远程资源库中不存在的jar包 xff0c 将jar包放在项目目录下 xff0c 并用 lt systemPath gt 的方式引用 xff0c windows系统本地调试的时候没问题 xff0c 部署到Linux能成
  • 彻底解决 error: Unable to find vcvarsall.bat

    1 windows上做Python开发 xff0c 搭环境还真不比Linux容易 error Unable to find vcvarsall bat这个错误眼熟吧 xff1f 凡是安装和操作系统底层密切相关的Python扩展 xff0c
  • ubuntu下解决微信不能发送图片的问题

    安装sudo apt install libjpeg62 i386 xff0c 可以解决ubuntu下不能发送微信截图的问题
  • dpkg安装deb缺少依赖包的解决方法--Ubuntu 16.04 LTS 安装网易云音乐

    一 去网易云音乐官网下载对应的安装包 我下载的是netease cloud music 1 0 0 2 amd64 ubuntu16 04 deb 二 开始安装 sudo dpkg span class hljs attribute i s
  • 个人号微信机器人API接口

    发送APP类消息 和发送小程序是同一个接口 xff0c 此接口可发送xml中包含appmsg的消息 xff0c 例如 xff1a 短视频 xff0c 直播 xff0c 音乐 xff0c 第三方APP等 请求URL xff1a http 域名
  • Fiddler抓包(下载安装及使用)

    一 下载安装 1 下载 官网链接 xff1a https www telerik com Fiddler Classic xff08 经典版 xff09 xff0c 这个版本是免费的 xff0c 不过只能在Windows上使用 Fiddle
  • URL&HTTP协议详解

    URL xff1a 统一资源定位符 这就意味着我们可以通过URL的方式去访问的资源 xff08 接口 xff09 URI xff1a 统一资源标识符 是一种抽象的概念 xff0c 本身没有具体去实现 一 URL URL是实现接口访问的第一步
  • CentOS7学习笔记(安装配置到常用命令)

    一 下载安装 访问linux org xff0c 选择centos xff0c 找到centos对应版本的镜像网站下载 新建虚拟机 安装 xff1a 语言默认英文 xff0c 最好不要改动 xff0c 不然有可能会有乱码问题 时区选择sha
  • Microsoft 365自定义安装,卸载Access、Publisher、Skype

    买电脑送的Office 2019只有Word Excel PowerPoint三件套 xff0c 一般情况都是够用的 xff0c 可以前往Microsoft 帐户 服务和订阅中下载一键安装 但是拥有Microsoft 365 xff08 原
  • Vimium如何使用

    Vimium是什么 vimium是一款支持全键盘操作浏览器的扩展 可以尽可能的解放鼠标 有一定的学习成本 xff0c 对本就拥有vim使用经验的人来说上手更容易 支持Chrome Edge Firefox 使用流畅后可以大大的提升浏览器的使
  • Linux 文件系统

    Linux 文件系统以及常见命令 Linux 文件系统block 与 inode文件类型权限目录树挂载 管道啥是管道管道的分类管道的实质 Linux 文件系统 在 Linux 中一切皆文件 xff0c 不仅仅是平时所使用的 txt pdf