linux文件——文件系统——学习、理解、应用软硬件链接

2024-09-01 05:28

本文主要是介绍linux文件——文件系统——学习、理解、应用软硬件链接,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

        前言:本篇内容主要讲解文件系统的软硬件链接。 经过前两篇文件系统的文章——讲解硬件(磁盘)、讲解文件系统底层, inode, 我们本节内容可以很好的理解我们要讲解的内容。 并且本节内容较少, 友友们学习本节的时候将会比前几节相对轻松一些。 

        ps:友友们务必了解磁盘的结构以及文件系统的底层原理以及inode, 再学习本节内容。

目录

软硬件链接——认识

什么是软链接

什么是硬链接

软硬件链接——底层原理

硬链接——深层挖掘

软链接——深层挖掘

软硬件链接的应用场景

软链接——实例应用

硬链接——实例应用

目录硬连接的死循环问题


软硬件链接——认识

什么是软链接

        首先, 我们先创建一个空文件, 如下图:

 

        然后, 我们就可以创建这个文件的软链接。 ——注意, 这里的文件是普通文件。 但是目录文件也可以, 最好使用普通文件, 因为好进行下面内容的测试

        上图中, ln就是链接的意思。 -s就是软链接, 然后file.txt就是连接到的文件——也就是目标文件, soft_link就是连接的文件——也就是软链接出的新文件。 也就是说, 由soft_link指向file.txt。

        而且, 我们使用ls -li, 也就是查看文件的inode编号, 会发现, soft_link的编号和file.txt是不一样的。如下图:

        所以, 我们就可以得出一个结论——软链接是一个独立的文件, 具有独立的inode。 

什么是硬链接

        接下来, 我们再创建一个test.txt

        接下来, 我们去掉-s, 直接ln test.txt hard_link——这就是创建硬链接, -s是创建软链接, 而如果去掉-s的话, 就是不创建软链接了, 也就是创建硬链接。 

        而观察硬链接的inode编号, 我们可以发现, 硬链接的编号和原文件相同。 那么我们这里就可以下另一个结论——硬链接没有独立的inode, 不是一个独立的文件。

        而且, 硬连接的文件属性中有一个地方发生了变化,上图中, 画圈圈的2处, 这个地方如果我们在实验的时候观察仔细就会发现, 在没有硬链接之前是1, 但是硬链接之后, 就变成了2. 我们这里再做一次实验:

        由实验我们真实的看到, 这里的数字从1变成了2。 而这个数字, 博主可以告诉友友们, 其实这个数字就是一个引用计数——这里从1变成了2, 本质上就是引用计数发生了变化!这个引用计数叫做硬链接数

软硬件链接——底层原理

硬链接——深层挖掘

        其实, 一般情况下, 我们学习软硬件链接只能学到上面的东西, 但是我们今天还要加深对于软硬件链接的理解。 对于硬链接来说, 我们知道, 硬链接的新文件和原文件的inode是一样的,但是文件名是不一样的。 而且我们又知道, 目录的块里面保存的是什么?——保存的是文件名和inode的映射关系!!! 这里为什么要说这个? ——因为硬连接的本质——其实就是在目录的块里面创建一个文件名和inode的映射关系!!!

         对于硬链接数来说, 我们知道任何一个文件,无论是目录, 还是普通文件, 都有inode。 对于inode内部, 都有一个叫做引用计数的计数器。 

        而由于目录里面保存的是:文件名和inode编号的映射关系! 所以多个文件名指向一个inode就有如下图结构:

        也就是说, 无论文件名如何变化, inode是不变的。 每一个文件名最终都会指向同一个inode换句话说, 就是每一个文件名最终都会指向同一个文件!!!

        所以我们在删除一个文件的时候(rm), 其实就是让该文件的inode里面的引用计数减减如果inode减到了0, 那么再进行inode的删除工作, 也就是我们上篇文章所讲到的删除文件的流程——简单说就是根据目录找到对应的文件的inode编号, 找到编号计算在哪个区, 哪个组当中。 然后根据inode编号找到block NUM, 将block bitmap置为0, 然后inode bitmap置为0. 

软链接——深层挖掘

        对于软链接来说, 软链接不会影响目标文件的引用计数, 那么就是说, 软连接的本质和硬链接是不同的。 那么软链接是什么情况呢?

        我们看下图的一个现象(soft_link是file.txt的软链接):

        这是为什么呢? 这是因为软链接里面的数据块里面, 保存的是所指向文件的路径!!!——也就是说, 软链接是一个独立的文件, 有独立的inode, 也有独立的数据块, 他的数据块里面保存的是指向文件的路径

        如果我们删除软链接, 那么没有问题。 但是我们如果删除软连接的目标文件, 就会发生错误, 因为软链接文件找不到原文件了。 如下图:

 

        软链接就像我们常用的快捷方式。 下面是一个快捷方式:

        我们桌面上的就是快捷键, 也就是相当于软链接, 然后我们的目标文件其实就是在图中的红框框的路径里。 而且我们可以删除快捷键, 但是如果我们删除了目标路径下的程序文件, 那么快捷方式也不能跑了。

        学到了软硬件连接的本质, 底层原理还不够, 我们还要学习一下软硬件连接的应用场景。 只有这样, 我们才算是真正的理解软硬件链接。 下面我们来认识一下具体的场景——

软硬件链接的应用场景

软链接——实例应用

我们先写一个程序,如下图, 代码很简单:

        我们直接在当前路径生成可执行程序。 

        然后我们将软链接文件创建在bin目录下(也就是bin下创建快捷键), 然后我们就可以在任何目录下直接使用文件名运行程序了, 如下图:

        这就是软链接的一个应用场景。

硬链接——实例应用

我们创建一个目录:

我们可以看到, 图中的这个新建的目录的硬链接数是2, 为什么呢? ——不知道友友们记不记得我们曾经说过——每个目录下都有.这个文件目录

        .目录就是目录本身——上图中的inode也证实了这一点。 而这个inode两者相同, 这就是为什么.是当前目录的原因, 也可以说是本质。——这就是硬链接的一个应用场景。 

        .谈完了, 再谈..

        ..我们说过是上级目录, 我们进入newdir, 并且记一下此时newdir目录的硬链接数, 以及inode编号:

        我们再在这个目录中创建文件, 就会看到newdir目录的硬链接数加了1, 并且新创建的文件agamk里面的..和newdir的inode是一样的。

        也就是说, ..和上一级目录指向的文件是一样的。 ..就代表上一级目录!!而且, 只要我们创建一个新的子目录, 当前目录的硬链接数就会加, 这是因为子目录的上一级目录文件的inode都是当前目录的inode!!!

        那么我们如果查看根目录下的硬链接数:

        如图是19, 那么我们就可以算出, 当前根目录下一共有多少个有效目录呢?——答案是17, 因为空目录为2, 所以19 - 2 = 17.

        而且, 我们知道, 正是因为有了.和.., 我们才得以进行路径的定位。 也就是说, 硬链接的一个作用是什么呢?——就是进行路径的定位!!

目录硬连接的死循环问题

        注意, linux系统不允许创建目录的硬链接。 ——即使.和..是硬链接, 但是这是系统默认的。 而我们的用户是不允许的, 为什么?

        下面我们看这么个情况。 

        下面是文件系统的树形结构图:

        如果我们在系统中查找某一个文件的时候, 我们当查到了上面的绿圈圈root, root告诉我们它是硬链接, 我们要返回inode为2的目录再去寻找, 而inode为2就是根目录。 也就是说, 当我们查到root的时候, 我们又会重新查一遍, 反反复复就会陷入死循环。 ——这就是为什么不能硬链接。

        但是可能我们会问, 不是刚刚才讲到, .和..不就是硬链接吗?为什么又说不能创建呢? 这是为什么呢?——这是因为操作系统默认已经把.和..创建好了。 操作系统不允许用户创建硬链接目录, 即便这个用户是root。 

        而且, 系统在搜索路径的时候, 不会去搜索.和.., 也就不存在环路问题!!!

——————以上, 就是本节的全部内容, 下面为本人学习笔记

这篇关于linux文件——文件系统——学习、理解、应用软硬件链接的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Linux join命令的使用及说明

《Linuxjoin命令的使用及说明》`join`命令用于在Linux中按字段将两个文件进行连接,类似于SQL的JOIN,它需要两个文件按用于匹配的字段排序,并且第一个文件的换行符必须是LF,`jo... 目录一. 基本语法二. 数据准备三. 指定文件的连接key四.-a输出指定文件的所有行五.-o指定输出

Linux jq命令的使用解读

《Linuxjq命令的使用解读》jq是一个强大的命令行工具,用于处理JSON数据,它可以用来查看、过滤、修改、格式化JSON数据,通过使用各种选项和过滤器,可以实现复杂的JSON处理任务... 目录一. 简介二. 选项2.1.2.2-c2.3-r2.4-R三. 字段提取3.1 普通字段3.2 数组字段四.

Linux kill正在执行的后台任务 kill进程组使用详解

《Linuxkill正在执行的后台任务kill进程组使用详解》文章介绍了两个脚本的功能和区别,以及执行这些脚本时遇到的进程管理问题,通过查看进程树、使用`kill`命令和`lsof`命令,分析了子... 目录零. 用到的命令一. 待执行的脚本二. 执行含子进程的脚本,并kill2.1 进程查看2.2 遇到的

Linux云服务器手动配置DNS的方法步骤

《Linux云服务器手动配置DNS的方法步骤》在Linux云服务器上手动配置DNS(域名系统)是确保服务器能够正常解析域名的重要步骤,以下是详细的配置方法,包括系统文件的修改和常见问题的解决方案,需要... 目录1. 为什么需要手动配置 DNS?2. 手动配置 DNS 的方法方法 1:修改 /etc/res

深入理解Mysql OnlineDDL的算法

《深入理解MysqlOnlineDDL的算法》本文主要介绍了讲解MysqlOnlineDDL的算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小... 目录一、Online DDL 是什么?二、Online DDL 的三种主要算法2.1COPY(复制法)

Linux创建服务使用systemctl管理详解

《Linux创建服务使用systemctl管理详解》文章指导在Linux中创建systemd服务,设置文件权限为所有者读写、其他只读,重新加载配置,启动服务并检查状态,确保服务正常运行,关键步骤包括权... 目录创建服务 /usr/lib/systemd/system/设置服务文件权限:所有者读写js,其他

Linux下利用select实现串口数据读取过程

《Linux下利用select实现串口数据读取过程》文章介绍Linux中使用select、poll或epoll实现串口数据读取,通过I/O多路复用机制在数据到达时触发读取,避免持续轮询,示例代码展示设... 目录示例代码(使用select实现)代码解释总结在 linux 系统里,我们可以借助 select、

Linux挂载linux/Windows共享目录实现方式

《Linux挂载linux/Windows共享目录实现方式》:本文主要介绍Linux挂载linux/Windows共享目录实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录文件共享协议linux环境作为服务端(NFS)在服务器端安装 NFS创建要共享的目录修改 NFS 配

linux系统中java的cacerts的优先级详解

《linux系统中java的cacerts的优先级详解》文章讲解了Java信任库(cacerts)的优先级与管理方式,指出JDK自带的cacerts默认优先级更高,系统级cacerts需手动同步或显式... 目录Java 默认使用哪个?如何检查当前使用的信任库?简要了解Java的信任库总结了解 Java 信

Linux命令rm如何删除名字以“-”开头的文件

《Linux命令rm如何删除名字以“-”开头的文件》Linux中,命令的解析机制非常灵活,它会根据命令的开头字符来判断是否需要执行命令选项,对于文件操作命令(如rm、ls等),系统默认会将命令开头的某... 目录先搞懂:为啥“-”开头的文件删不掉?两种超简单的删除方法(小白也能学会)方法1:用“--”分隔命