【Linux】—— 详解软硬链接

news2024/12/23 20:33:30

前言:

  • 本期,我将要给大家讲解的是有关 Linux下软硬链接的相关知识!!!

目录

前言

(一)理解硬链接

1.什么是硬链接

2.创建硬链接

 3.硬链接的使用场景

(二)理解软链接

1.什么是软链接

2.创建软链接

3.软链接使用场景

(三)硬链接和软链接的对比

总结


前言

文件共享可以使多个用户共享同一份文件,系统中只需保存该文件的一个副本即可,若系统不能提供共享功能,则每个需要该文件的用户都要有各自的副本,会造成对存储空间的浪费。

现代常用的两种文件共享方法如下:

  1. 基于索引结点的共享方式(硬链接
  2. 利用符号链接实现文件共享(软连接

接下来,我将为大家详细的介绍上述这两种文件共享方式!!! 


(一)理解硬链接

1.什么是硬链接

在树形结构的目录中,当有两个或多个用户需要共享一个子目录或文件时,必须将共享文件或子目录链接到两个或多个用户的目录中,才能方便找到该文件。

  • 如下图所示:

【解释说明】

  1. 在这种共享方式中,诸如文件的物理地址及其他文件属性等信息,不再放在目录项之中,而是放在索引结点中。在文件目录中只设置文件名及其指向相应的索引结点的指针;
  2. 在索引文件中还有一个count 计数器,用于表示链接到本索引结点上的用户目录项个数;
  3. 当 count = 2 时,表示有两个用户目录项链接到本地文件中,或者说有两个用户共享此文件。

因此,根据上述的简单介绍。接下来我将便引出了有关硬链接的相关定义:

  • 硬链接(Hard Link)是计算机文件系统中的一种链接方式,用于将一个文件与另一个文件或目录关联起来,使它们共享相同的数据块和inode(索引节点)。其次硬链接允许一个文件在文件系统中存在多个入口点,这意味着对一个硬链接文件的更改将反映在所有与之相关联的硬链接上,因为它们实际上都指向相同的数据

2.创建硬链接

创建硬链接是在文件系统中创建一个指向目标文件的硬链接,硬链接与目标文件共享相同的 inode 和数据块,它们在文件系统中被视为同一实体,即使使用不同的文件名。

  • 要创建硬链接,您可以使用ln命令。具体的命令格式如下:
ln <目标文件> <链接名>

以下是使用ln命令创建硬链接的示例:

 【解释说明】

  • 我们可以发现硬链接和目标文件用同一个 inode number ,这也就意味着硬链接一定是和目标文件使用同一个inode的!!
  • 硬链接与目标文件具有相同的权限、时间戳和内容,因此对于用户来说,它们是透明的。当对目标文件或硬链接进行更改时,对另一个对象也会产生影响。
  • 因此硬链接就是建立了新的文件名和老的 inode的映射关系。

💨 删除目标文件不会立即删除其硬链接,只有当最后一个指向该文件的硬链接被删除时,才会真正释放磁盘空间

  • 除了上述这种删除操作之外,我们还可以使用 unlink 指令。具体如下:

【解释说明】 

我们在删除文件时干了两件事情:
  • 1.在目录中将对应的记录删除;
  • 2.将硬连接数-1,如果为0,则将对应的磁盘释放。

【解释说明】

  • 由于在文件系统中所有硬链接都指向同一个数据块,每个文件将累积相同的磁盘空间。该磁盘空间的大小是目标文件本身的大小加上与其关联的硬链接数。这就解释了为什么使用ln命令创建硬链接后,使用ls -li命令查看文件属性时,硬链接所占用的磁盘空间(count列)会随之增加;
  • 其次每当创建一个新的硬链接时,与目标文件关联的硬链接数都将增加1,这也会使被关联的目标文件的硬链接计数器增加1,同时即使数据块仅存储一次,该文件也会在文件系统中以多个名称存在。这是硬链接的重要特性之一。

 3.硬链接的使用场景

  • 首先,大家先看实验现象,我们根据实验现象来进行推理:

【现象解释】

  1. 根据上述我们看发现,对于普通文件来说,创建之后默认的硬链接数是为1;
  2. 而对于目录来说,硬链接数默认的是为2

接下来,我们进入到 dir目录下:

【解释说明】

  1. 进入到dir目录下,我们可以发现目录都包含两个特殊的条目,一个是表示自身的'.',另一个是表示父目录的'..';
  2. 对于 “.” 来说,我们可以发现它的inode number 跟目录dir的 node number 是一样的。这也解释为什么说 “.” 表示当前路径,而“..” 表示上级路径的原因。

上述表示可能没有直观的显示,下图直观的显示了 “.” 和 “..” 所指:

【小结】

  1. 对于普通文件,一个inode通常只有一个硬链接。当你创建一个文件时,系统会分配一个inode,并且这个文件会被视为该inode的第一个硬链接。所以,普通文件的硬链接数是1,代表着这是该文件的第一个硬链接。
  2. 对于目录,至少有两个硬链接。一个是目录本身的条目,另一个是指向该目录的父目录中的条目。因为每个目录都包含两个特殊的条目,一个是表示自身的'.',另一个是表示父目录的'..'。所以,目录的硬链接数至少是2。

总结起来,普通文件的硬链接数为1,因为它只有一个硬链接,而目录的硬链接数至少为2,因为它包括一个自身的硬链接和一个父目录的硬链接,并且会随着目录中的文件和子目录的增加而增加。


 【注意事项】

💨 对于目录结构来说是不能创建硬链接的。具体如下:

【解释说明】

  1. 目录不容易创建硬链接的主要原因是为了维护文件系统的一致性和避免潜在的问题;
  2. 最主要的就是循环引用问题:如果目录A有一个硬链接指向目录B,而目录B又有一个硬链接指向目录A,这将创建一个循环引用。这会导致文件系统遍历目录时出现无限循环,可能引发严重的问题。

(二)理解软链接

1.什么是软链接

为使用户 B 能够共享用户 A的一个文件FILE,可以由系统创建一个LINK类型的新文件,也取名为FILE,并将该文件写入用户B的目录中,已实现用户B的目录与文件FILE的链接。

  • 如下图所示:

 【解释说明】

  1. 在新文件中只包含被链接文件的路径名;
  2. 当用户B要访问被链接的文件且正要读LINK类型新文件时,操作系统查看到要读文件是LINK类型,则根据文件中的路径名去查找到该文件,然后对它进行读,从而实现共享操作

因此,根据上述的简单介绍。接下来我将便引出了有关软链接的相关定义:

  • 软链接(Symbolic Link,也称为符号链接或符号连接)是计算机文件系统中的一种特殊类型的链接。与硬链接不同,软链接是一个指向另一个文件或目录的引用,类似于一个快捷方式或别名。它包含指向目标文件或目录的路径信息,而不是直接引用相同的数据块和inode。

2.创建软链接

创建软链接是在文件系统中创建一个指向目标文件或目录的符号链接。软链接类似于Windows系统中的快捷方式,它提供了一种方便的方式来引用目标文件或目录。

  • 在Linux系统下,可以使用ln命令来创建软链接,具体的命令格式如下:
ln -s <目标文件或目录> <链接名>
//其中,-s表示创建软链接。

以下是使用ln命令创建软链接的示例:

 【解释说明】

  1. 文件系统中创建了一个名为my-soft的软链接,它指向了名为myfile.txt的目标文件。链接的权限模式通常显示为lrwxrwxrwx,其中l表示该文件是一个软链接;
  2. 软链接的大小通常会显示链接路径的字符数,因此其大小为10。请注意,这里的大小指的是链接本身的大小,而不是目标文件的大小;
  3. 软链接也是一个独立的链接文件,有自己的 inode number,因此必有自己的 inode属性和内容(内容表示的是软链接内部放的是自己指向的文件路径);
  4. 上述已表明软链接已成功创建,并且您可以通过访问my-soft来间接访问myfile.txt;

 紧接着,我们试着去查看 my-soft 中内容,看是否链接成功:


这意味着对my-soft所做的更改将反映在myfile.txt中,而且删除myfile.txt也会影响到my-soft

  • 例如,如果执行以下命令:
rm myfile.txt

【解释说明】 

  1. 软链接提供了一种灵活和便捷的方式来引用目标文件或目录,但需要注意的是,当目标文件或目录被删除时,软链接将指向一个无效的目标;
  2. 因此确保在使用软链接时,目标文件或目录的存在性和有效性是至关重要的。

3.软链接使用场景

比如说,今天有一个可执行程序在系统中的某一个路径下藏得很深,或者自己写的一个软件放在系统很深的目录下时就考虑使用。

  • 首先,我们先创建一个test.c 文件:

  • 假如此时形成的可执行文件 mytest 放在一个很深的目录下,而要求我们在此路径下执行:

  • 如果不采用软链接的方式去执行就会显得十分的麻烦:

【小结】

  • 因此,综上所述我们可以得出软链接就是将一个路径很深的程序或者库、头文件等在当前路径下或者一个很好找的路径下能够快速的去访问到这个文件,这就是我上述所说的像 windows下快捷方式的原因 。

(三)硬链接和软链接的对比

硬链接(Hard Links)和软链接(Symbolic Links,也称为符号链接)是两种在文件系统中创建文件链接的不同方法,它们有一些重要的区别:

  1. 链接的类型

    • 硬链接:硬链接是文件系统中的多个文件项,它们都指向同一个inode(磁盘上的数据块和元数据)。这意味着硬链接之间没有所谓的原始和副本,它们都是相等的。删除任何一个硬链接都不会影响其他硬链接,只有当所有硬链接都被删除后,文件的内容才会被释放。
    • 软链接:软链接是一个特殊类型的文件,其中包含了指向另一个文件或目录的路径。软链接本身是一个独立的文件,它存储了目标文件的路径信息。如果原始文件或目录被删除,软链接仍然存在,但它会成为一个"死链接",指向一个不存在的目标。
  2. 跨文件系统

    • 硬链接:通常只能在同一文件系统内创建硬链接,因为硬链接与inode相关,而不同文件系统的inode不会关联。
    • 软链接:软链接可以跨越文件系统边界,因为它们只是包含目标路径的文本文件。
  3. 文件类型

    • 硬链接:只能链接到文件,不支持链接到目录。
    • 软链接:可以链接到文件或目录,也可以链接到其他软链接。
  4. 大小和性能

    • 硬链接:硬链接几乎没有大小,因为它们共享相同的inode和磁盘块。由于硬链接不需要额外的磁盘空间,因此通常更高效。
    • 软链接:软链接的大小通常比硬链接大,因为它们需要存储目标路径信息。软链接需要解析目标路径,这可能会引入微小的性能开销。
  5. 修改和权限

    • 硬链接:硬链接的修改会反映在所有硬链接上,因为它们都共享相同的inode。硬链接之间没有权限区别。
    • 软链接:软链接的修改不会影响目标文件或目录,因为它们只是指向目标的路径。软链接和目标之间可能具有不同的权限设置。
  6. 用途

    • 硬链接:常用于备份工具和版本控制系统,可以减少磁盘占用,因为它们共享相同的数据块。
    • 软链接:常用于创建快捷方式或引用其他位置的文件或目录,也用于跨文件系统的链接。

总结

总之,硬链接和软链接都有各自的用途和限制,选择哪种链接类型取决于您的需求和文件系统结构。硬链接更适合共享相同数据的文件,而软链接更适合创建引用或跨越文件系统的链接

到此,关于软硬链接的介绍便讲解完毕了。感谢大家的观看和支持!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1059670.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

麦田物语学习

设置预设 将对一个物体的操作保存下来&#xff0c;直接用于其他的物体&#xff0c;比较省力 当设置好一个物体后点击箭头所指的地方&#xff0c;保存预设&#xff0c;在其他物体的面板里点击预设使用 sprite renderer 图片渲染顺序参考点 修改游戏的渲染方式 修改为按照 y 轴…

操作系统学习笔记2

文章目录 1、进程管理逻辑图2、进程的由来 参考视频&#xff1a; 操作系统 1、进程管理逻辑图 2、进程的由来

芯驰D9评测(2)--系统环境配置连接

linux开发板的软件开发三件套&#xff1a; 建立连接-->建立交叉编译环境-->建立驱动开发环境。 如果我们不涉及镜像的深度定制&#xff0c;只是平台化应用的话 1. 建立串口连接 查看手册&#xff0c; 获取接口定义说明&#xff1a; 板载一共两个端子&#xff0c;三个…

python二次开发CATIA:文字轮廓草图

CATIA V5 版本的草图中&#xff0c;并没有文字轮廓的创建命令。通常的做法是&#xff0c;再Drawing 文件中创建所需文本-->将 Drawing 文件另存为 dwg / dxf 格式-->打开另存的文件&#xff0c;文字已转为轮廓线条-->复制线条并粘贴到草图中。 本例中&#xff0c;基于…

c#+Mysql房屋租赁管理系统

一、引言 随着房价的不断升高&#xff0c;人们对房屋的需求越来越难以满足&#xff0c;对于一些在外地工作的人来说租房子成为了一种常态&#xff0c;因此出现了越来越多的房屋中介&#xff0c;而对于房屋中介而言&#xff0c;管理日益增加租户的信息和房产的信息成了一个至关…

Hono——一个小型,简单且超快的Edges Web框架

Hono - [炎]在日语中的意思是火焰&#x1f525; - 是一个小型&#xff0c;简单且超快的Edges Web框架。它适用于任何JavaScript运行时&#xff1a;Cloudflare Workers&#xff0c;Fastly ComputeEdge&#xff0c;Deno&#xff0c;Bun&#xff0c;Vercel&#xff0c;Netlify&…

【Leetcode】滑动窗口合集

这里写目录标题 209.长度最小的子数组题目思路代码 3. 无重复字符的最长子串&#xff08;medium&#xff09;题目思路 11. 最大连续 1 的个数 III题目思路 1658. 将 x 减到 0 的最⼩操作数题目思路代码 904. 水果成篮题目思路代码 438.找到字符串中所有字母的异位词题目思路代码…

政治与科技

作者&#xff1a;Hal Finney, 1994.1.2 今天政府可以禁书吗&#xff1f;当然不&#xff0c;至少在一个人将其输入或扫描到计算机中之后不能。技术成果是永久性的。政治手段只能作为一种战术武器&#xff0c;在技术解决方案到位之前阻止它们。如果你想改变世界&#xff0c;就不要…

Pytorch目标分类深度学习自定义数据集训练

目录 一&#xff0c;Pytorch简介&#xff1b; 二&#xff0c;环境配置&#xff1b; 三&#xff0c;自定义数据集&#xff1b; 四&#xff0c;模型训练&#xff1b; 五&#xff0c;模型验证&#xff1b; 一&#xff0c;Pytorch简介&#xff1b; PyTorch是一个开源的Python机…

python二次开发CATIA:为选中元素上色

先打开一个零件文档&#xff0c;然后用鼠标选中元素&#xff0c;再运行如下python程序&#xff1a; import win32com.client import pywintypes # 导入pywintypes模块 import random # 启动CATIA应用 catia win32com.client.Dispatch(CATIA.Application) catia.visible1try:…

在OpenWrt中配置使用FTP文件服务

安装&#xff1a;opkg install vsftpd 配置&#xff1a;vim /etc/vsftpd.conf 在其中增加一行&#xff1a;local_root/tmp 重启&#xff1a;service vsftpd restart

基于B2B平台的医疗病历交互系统

目录 前言 一、技术栈 二、系统功能介绍 医院管理 医院注册 医院文章 医生信息 医院注册 医疗安排 院区注册 医院公告 医院工作人员 病人病历 三、核心代码 1、登录模块 2、文件上传模块 3、代码封装 前言 进入21世纪&#xff0c;计算机技术迅速向着网络化的、集…

pytorch最后一步安装失败显示false怎么办?

这两天在安装pytorch&#xff0c;可谓是吃了不少苦&#xff0c;安了整整一天才安装好。 本来按照安装步骤&#xff0c;一步一步都进行的很好&#xff0c;可是最后一步却显示false。 我的解决方案是&#xff0c;先更新显卡驱动&#xff08;注意我的是英伟达显卡&#xff0c;安…

什么是向量嵌入?

一、说明 在所有关于生成式AI的讨论中&#xff0c;为生成式AI提供动力背后的概念可能有点压倒性。在这篇文章中&#xff0c;我们将重点介绍一个功能概念&#xff0c;它为人工智能的潜在认知能力提供支持&#xff0c;并为机器学习模型提供学习和成长的能力&#xff1a;向量嵌入。…

【C语言】浅谈代码运行效率及内存优化

【C语言】浅谈代码运行效率及内存优化 C语言作为一种高效率的编译语言 常用来写单片机等讲究时序性的设备 而只有代码优化得好 才能提高运行效率 当然这里的代码优化 并不是编译器优化 而是人为的代码习惯 文章目录 代码效率条件判断if else语句 抛弃边缘状态中断函数串口解析…

算法基础学习|排序

快速排序 模板 void quick_sort(int q[], int l, int r) {if (l > r) return;int i l - 1, j r 1, x q[l r >> 1];while (i < j){do i ; while (q[i] < x);do j -- ; while (q[j] > x);if (i < j) swap(q[i], q[j]);}quick_sort(q, l, j)&#xf…

希尔排序(C++实现)

文章目录 前言1. 基础概念2. 动图演示3. 代码实现4. 排序过程5. 效率分析6. 总结 前言 上篇文章讲了直接插入排序算法。 首先&#xff0c;在待排序的数组中&#xff0c;元素本身就是有序的情况下&#xff0c;就不需要移动任何元素&#xff0c;所以直接插入排序最好情况时间复…

Javascript 事件的动态绑定

动态绑定事件&#xff0c;是指在代码执行过程中&#xff0c;通过Javascript代码来绑定事件。这种技术可以大大增强网页的交互性和用户体验。上一期介绍的是通过事件监听器 EventListener 去实现元素颜色的变化。这一期将通过动态绑定方法去实现&#xff0c;对象.事件 匿名函数…

哈希/散列--哈希表[思想到结构]

文章目录 1.何为哈希?1.1百度搜索1.2自身理解1.3哈希方法/散列方法1.4哈希冲突/哈希碰撞1.5如何解决?哈希函数的设计 2.闭散列和开散列2.1闭散列/开放定址法2.2开散列/链地址法/开链法1.概念2.容量问题 3.代码实现[配备详细注释]3.1闭散列3.2开散列 1.何为哈希? 1.1百度搜索…