跳至主要內容

Linux的文件结构

maijunxuan约 4049 字大约 14 分钟

Linux的文件结构

了解一下文件类型

Linux采用的一切皆文件的思想,将硬件设备、软件等所有数据信息都以文件的形式呈现在用户面前,这就使得我们对计算机的管理更加简介明了。所以在展开文章后续文章的讨论一下,我们不妨花一个小节了解一下Linux中常见的文件类型(注意,笔者为了能够更好的展示各个文件夹下的文件,使用的是root账号)

首先我们键入到达~目录

cd ~

然后键入ll查看所有非隐藏文件,注意笔者描述,是非隐藏文件哦,可以看到在每个文件最前方都有一个由10个字符构成的字符串,就以第一行为例-rw-------.,这就是文件类型和权限组成的字符串,由于笔者这里仅只对文件属性介绍,所以我们只对这个字符串的第一个字符串展开讨论(文件权限内容会在后文详尽讲述) 可以看到第一行的10字符的第一个字符是-,在Linux操作系统中,这个符号就代表着文件是一般文件,何为一般文件呢?通俗的理解就是你日常所能看到的txt、conf等各种各样没有任何特点,仅仅记录一些数据的文件就是一般文件了。

image-20220905194910182

除了最平凡的一般文件意外,每个文件第一栏的第一个字符还可能出现以下几种情况

        1. d:代表当前文件为文件夹
        2. l:代表当前文件为超连接文件
        3. b:该文件提供为提供给系统存取的设备,例如你计算机的硬盘所存储的数据内容,可能都会保存在这个类型文件中
        4. c:代表着连接到你计算机的一些硬件设备,例如鼠标、键盘等配置文件开头都是以c开头的

有了这些概念之后,我们就可以对这些文件属性展开验证了,首先d代表文件夹,我们不妨创建一个文件夹,看看该文件是不是以d打头的吧(为了遵循Linux文件存储规范,笔者的操作尽量都会在tmp中演示)

首先我们在tmp目录下创建一个dir文件夹

mkdir /tmp/dir

我们在用如下命令查看dir的文件属性

ll /tmp/

可以看到我们创建的文件夹是以d打头的

image-20220905194928297

上文还提到了一个b打头的文件,这个文件是提供系统存储的数据且可能硬盘也可能是其他存储设备的,这类型文件一般都在设备目录dev下,我们不妨使用如下命令查看

ll /dev/sda

image-20220905194943467

而c打头的文件则是硬件设备,我们不妨键入 ll /dev查看一下,如下图所示的bus总线,以及cpu等这些都是硬件设备

image-20220905194953850

同样的在上文中我们也有提到关于隐藏文件的概念,在Linux中隐藏文件大多以.开头,这些文件使用常规的ll、ls等命令是看不到的,所以我们需要使用如下命令,注意这里的a就代表all的意思哦

ls -al查看

可以看到,所有的隐藏文件也都显示出来了

image-20220905195033612

文件名的限制

在现如今的Linux低下,文件系统基本采取XFS,所以文件名长度限制基本是255byte,说通俗一点,你的文件要是以英文命名就可以起一个长度为255的文件名,若为汉字则长度大约是127。注意由于Linux命令中常会用到-以及一些特殊符号,所以文件命名应该尽量避免一下几个特殊符号

* ? > < ; & ! [ ] | \ ' " ` ( ) { } -

树形目录结构

了解了文件相关属性之后,我们再深入研究Linux的文件结构吧,总的来说Linux的文件结构类似于一棵树,如下图,需要了解的是,无论是何种Linux系统,他的目录都会遵循一个标准,包括下图中的文件结构,而这个标准名为Filesystem Hierarchy Standard (FHS)

image-20220905195053633

FHS规定文件的整体结构应该是这样的:

1. /:根目录,与开机系统有关
2. /usr(unix software resource):与软件的安装和执行有关
3. /var(variable):与系统的运作有关

首先介绍一个根目录/,他的文件内容如下所示,可以看到他的子节点文件基本都是和系统开机相关、各种程序、库函数的文件夹,所以在根目录这一级是非常重要的,所以FHS希望后续使用Linux的时候尽量不要将文件夹、文件都无脑扔到这一级。假如你真的无脑扔到这了,将来有一天你的误操作导致根目录崩坏,很可能导致系统无法修复、还原、开机。

image-20220905195113144

了解了根目录之后,我们再来介绍一下根目录下对应的文件夹,首先是/bin,我们日常使用Linux的时候都会用到ls、cat、touch、mkdir等命令,其实这些命令都是一些可执行文件,存放于bin目录下,如下图

image-20220905195127851

接下来是/boot,这个目录存放的基本都是Linux开机会用到配置文件,像Linux kerne常用到的文件名vmlinuz就会存放在这个文件夹下

image-20220905195141265

接下来是/dev,这个文件夹基本存放的都是硬件设备,我们都知道Linux主张一切皆文件,所以所有的鼠标、键盘、硬盘的设备信息都是存放在这个文件夹下

image-20220905195204472

/etc目录则是存放配置文件的地方,常见我们的用户文件/etc/passwd,以及密码文件/etc/shadow,还有系统文件/etc/rc等都会存放在这个目录下。 除此之外还有一些文件夹,例如mnt存放挂载相关,lib存放库函数相关、sbin开机、系统还原、修复等众多指令,以及临时文件夹tmp等。

我们再来聊聊FHS规范的另一个文件夹,即/usr,很多人最初都会误以为这是user的缩写,其实这个单词是unix software resource的缩写,这个文件夹是FHS规定存放软件资源相关的文件夹,他们建议用户软件相关的资源尽可能都放到这个目录

首先来看看/usr/bin目录,这个目录实质上就fhs希望用户能够将一般用户所能够的使用的指令都放到这个目录下,需要补充的是bin目录下的命令大部分都以及软链接到这个文件夹下了,我们查看根目录就能看出这一点

image-20220905195219201

同样的我们也能够在usr/bin目录下看到这个指令

image-20220905195229225

/usr/lib/ 基本上,与 /lib 功能相同,所以 /lib 就是链接到此目录中的,不多赘述。而/usr/local/则是fhs希望用户将下载的软件都放到这个目录下统一管理。/usr/sbin/则是存放一些比较重要的系统指令,同理sbin下的指令也会被软链接到这个文件夹下。

最后我们再来介绍一些/var目录了,这个目录fhs认为应该存放那些经常发生变化的文件,例如日志,他们希望日志统一存放到/var/log下。/var/lib存放的则是会临时改变的库文件。而/var/lock存放的则是被某个程序锁定的文件,已确保其他程序不回同时使用到这个文件。

绝对路径和相对路径

了解了各个文件架构,我们在了解一下绝对路径和相对路径的概念。绝对路径则是以根节点作为其实节点的文件搜寻办法,例如我们想到达tmp文件夹,如果使用绝对路径的方式则是

cd /tmp

假如我们在boot目录下,而tmp和他一样都属root的子节点,所以使用相对路径的方式是先退到root目录,然后再进入tmp文件夹,如下图,所以在boot目录下,我们进入tmp文件夹的命令为 cd ../tmp/

image-20220905195258808

需要补充的是,../代表着退到上一级,那么就会有这么一个指令./,代表当前目录,这个指令是干什么用的是,很简单,假如我们Linux中某个sh文件不在bin、sbin、/usr/bin这样的目录下,Linux规定我们执行可执行sh文件文件时都必须标明./,例如我在tmp目录下有个执行脚本test,那么我在test目录下执行这个脚本的格式就必须是

sh ./test.sh

文件权限

了解一下权限对应角色

了解了文件和文件属性等信息后,我们再来谈谈文件角色和权限管理这个话题。在展开这个话题之前,我们必须了解一下Linux文件下的角色划分。

我们在随意一个目录下键入ll查看文件信息,如下图我们可以看到每个文件的第一栏除去第一个字符串代表着文件类型外,其余字符都会显示rwx-相关,这是说明意思呢?

很简单,r代表读权限,w代表写权限,而x代表执行权限。

image-20220905195318293

那么问题来了,为什么rwx-这样的字符串,会重复三遍呢?这就是Linux系统对不同角色的权限划分,以第一行文件为例,我们把权限按照如下所示拆开,第一个字符代表他是给文件夹,2-4代表当前所有者权限为读写执行都有,而5-7代表所属组权限,即这个文件所属的组所拥有的权限为读和执行,最后一行代表其他人的权限也是读和执行。

d   rwx   r-x     r-x.

那什么又是所有者、所属组、其他人呢?还是以第一行为例,可以看到第3列为root,说明这个文件属于root的,root用户拥有读写执行权限。而第4列也为root,说明属于root组的用户拥有读写执行的权限。

假如此时有个名为xiaoming的用户进来,它属于xiaomingzu,那么对于这个dir文件夹而言,他就是other用户,他的权限就是第三列的读和执行权限了。

目录与文件对应权限的相似与区别

需要补充一点,在Linux系统下文件系统下,文件的可执行权限和文件夹的可执行权限是有所不同的。假如一个用户对文件夹只有读和写权限,那么他就无法进入到这个目录,如下所示,我们有root创建一个testDir,所以对于其他用户来说只有读和写权限。 注意一下笔者赋权的命令,这里我们需要了解一下Linux中r用4表示,w用2表示,x用1表示,所以766为(4+2+1)+(4+2)+(4+2)代表着所属者读写执行,所属组和其他都是读和执行

# 进入tmp目录
 cd /tmp/
 # 创建testDir文件夹
mkdir testDir
# 设置这个文件夹 所属者有所有权限 所属组和其他用户只有读和写权限
chmod 766 testDir/

所以当笔者以其他用户登录(这个用户不是所属者root也不属于root组)时,就会报出没有权限的问题

image-20220905195349968

这时候我们希望其他用户可以有执行的权限,要怎么做呢?很简单,我们也可以参考上面的数学公司对其他用户增加执行权限,即

chmod 777 /test/testDir

当然我们也可以单独对其他用户增加一个可执行权限,命令如下所示,可以看到其他为o,增加一个可执行权限为+x。同理可知若是所者为u,所属组为g。增加权限用+,减去权限用-,赋值权限用=

chmod o+x testDir/

所以我们若希望所属者赋值为所有权限则是u=rwx,所属组和其他都希望是读和执行,那就是go合在一起写,并=rx,如下所示:

 chmod u=rwx,go=rx testDir/

当然有时候你希望这个文件改变所属组,你也可以这么做

# 将文件夹testDir所属组改为zhangshiyu
chgrp zhangshiyu testDir/

此时所属组就会改变了

image-20220905195404716

若你希望改变所有者则可以

chown zhangshiyu testDir/

此时所有者就改变了

image-20220905195422099

当然,若你希望所有者和所属组都能改变则可以

# 将testDir所有者改为冒号左边的root,将所属组改为冒号右边的root
chown root:root testDir/

image-20220905195433739

回到原题,为了方便演示文件和文件夹可执行权限的区别,我们将文件夹所属者和所属者都改为root,并且所有用户都具备所有权限

chmod 777 testDir/
chown root:root   testDir/

image-20220905195451605

然后进去该文件夹,创建一个file1的文件,权限设置为700,即可所属者才有权限,所属组和其他没有任何权限

cd testDir/
 touch file1
 chmod 700 file1

使用ll -d查看testDir文件夹以及文件夹下对应的文件file1的权限,可以发现对于其他用户而言文件夹有所有的权限,而文件没有任何权限

ll -d  /tmp/testDir/ /tmp/testDir/file1

image-20220905195506527

所以我们使用别的账户可以进入路径,但是无法读写该文件如下图

image-20220905195523013

vim file1 

但是以为其他用户拥有file文件的目录testDir的执行权限,所以它可以将这个文件删除。所以得出结论,文件夹的可执行权限意为着可以删除这个文件夹下所有的文件,但是并不意味着可以修改或者读取文件夹下文件的内容。 这种情况我们完全可以将文件夹testDir看作一个抽屉,任何人对其都有任何权限。此时root往里面放了一个小保险盒,读写权限只有root有。所以其他用户是无法打开或者修改盒子中的内容。但是他具有抽屉(testDir)的所有权限,所以他可以将这个保险盒扔掉。

以下这张表格就说明了操作文件夹下某些文件所需的最低权限,可以看到像删除、复制等这些无需读取文件内容的操作,文件所对应的文件夹甚至不一定需要rw的权限。用上面抽屉和文件的例子来说,我们删除完完全全可以看不到抽屉内部文件的具体的内容,复制文件不需要知道文件夹内有什么文件,我们完完全全可以瞎摸出来放到别的目录。

在这里插入图片描述

文件目录与默认权限以及隐藏权限

补充:如果我们希望创建的文件默认umask为0022 导致创建的文件权限为 644 创建的文件夹权限为 755

如果我们将umask改为0000

umask 0000

创建的文件权限就是 666 创建的文件夹就是 777

上次编辑于:
贡献者: MJX