linux 里有硬链接和软连接两种概念。要明白这些概念首先要明白文件在linux 上其实有3个组成部分。

data 真正的数据存储区域

inode 一个用来唯一表示data的数据结构

filename 指向inode

硬链接

hard link是说增加一个filename point到inode。 这里的重点是inode不变,data不变。只是filename多了一个。因为inode 不变,而inode是跟文件系统一一对应的,所以硬链接不能跨文件系统。

软连接

soft link是说增加了一个新的文件,即一个新的data区域 一个新的inode, 一个新的filename。但是data 中存储的内容是指向源文件的一个指针。因为软连接多了一个inode, 所以软连接可以跨文件系统。

下面的步骤可以更详细的展示文件,硬链接 软连接的关系

首先创建一个文件large。 如下例子中

stat 显示了 Inode 为4298673113

ls -l 显示了 large文件的大小为9.4G 引用数 为1 (-rw-r--r--. 1 这里的1是引用数)

[root@node1 test]# stat large
File: ‘large’
Size: 10000000000 Blocks: 19531256 IO Block: 4096 regular file
Device: fd02h/64770d Inode: 4298673113 Links: 1
Access: (0644/-rw-r--r--) Uid: ( 0/ root) Gid: ( 0/ root)
Context: unconfined_u:object_r:user_home_t:s0
Access: 2015-09-24 15:55:42.703757216 +0800
Modify: 2015-09-24 15:55:51.054222277 +0800
Change: 2015-09-24 16:14:12.166408739 +0800
Birth: -
[root@node1 test]#
[root@node1 test]# ls -lh large
-rw-r--r--. 1 root root 9.4G Sep 24 15:55 large

其次我们创建一个硬链接如下:

stat 显示了 Inode 为4298673113 ,两个文件都是。

ls -l 显示了 两个文件的大小为9.4G 引用数 为2

这是因为硬链接只是为文件多建立了个名字。即引用多了一个。而inode不变。文件的大小也不变。

[root@node1 test]# stat large
File: ‘large’
Size: 10000000000 Blocks: 19531256 IO Block: 4096 regular file
Device: fd02h/64770d Inode: 4298673113 Links: 2
Access: (0644/-rw-r--r--) Uid: ( 0/ root) Gid: ( 0/ root)
Context: unconfined_u:object_r:user_home_t:s0
Access: 2015-09-24 15:55:42.703757216 +0800
Modify: 2015-09-24 15:55:51.054222277 +0800
Change: 2015-09-24 16:17:47.855250627 +0800
Birth: -
[root@node1 test]# ls -lh large
-rw-r--r--. 2 root root 9.4G Sep 24 15:55 large
[root@node1 test]#
[root@node1 test]# stat large.hard
File: ‘large.hard’
Size: 10000000000 Blocks: 19531256 IO Block: 4096 regular file
Device: fd02h/64770d Inode: 4298673113 Links: 2
Access: (0644/-rw-r--r--) Uid: ( 0/ root) Gid: ( 0/ root)
Context: unconfined_u:object_r:user_home_t:s0
Access: 2015-09-24 15:55:42.703757216 +0800
Modify: 2015-09-24 15:55:51.054222277 +0800
Change: 2015-09-24 16:17:47.855250627 +0800
Birth: -
[root@node1 test]#
[root@node1 test]# ls -lh large.hard
-rw-r--r--. 2 root root 9.4G Sep 24 15:55 large.hard
[root@node1 test]#

我们在创建一个软连接文件

stat 显示inode变了

ls -lh 显示引用为1 而大小也变了。

这是因为软连接是一个新的文件,其filename是新的,inode是新的,data区域也是新的。data区域的内容是指向源文件的。所以引用为1 inode 不一样而且大小也不一样

[root@node1 test]# stat large.soft
File: ‘large.soft’ -> ‘large’
Size: 5 Blocks: 0 IO Block: 4096 symbolic link
Device: fd02h/64770d Inode: 4298672263 Links: 1
Access: (0777/lrwxrwxrwx) Uid: ( 0/ root) Gid: ( 0/ root)
Context: unconfined_u:object_r:user_home_t:s0
Access: 2015-09-24 16:21:35.503190700 +0800
Modify: 2015-09-24 16:21:35.503190700 +0800
Change: 2015-09-24 16:21:35.503190700 +0800
Birth: -
[root@node1 test]# ls -lh large.soft
lrwxrwxrwx. 1 root root 5 Sep 24 16:21 large.soft -> large

  

更进一步去理解硬链接可以用如下的例子:

我们有如下3个文件

[root@node1 test]# ls -l *
-rw-r--r--. 1 root root 10000000000 Sep 24 16:23 big
-rw-r--r--. 2 root root 10000000000 Sep 24 15:55 large
-rw-r--r--. 2 root root 10000000000 Sep 24 15:55 large.hard

这几个文件大小一样。large和large.hard互为硬链接。

我们再看man rm 输出的一句话

Remove (unlink) the FILE(s)

这说明rm操作其实是给文件去掉一个link (也就是硬链接)但如果文件去掉一个硬链接之后没有更多的引用了,操作系统会回收文件所占用的空间。

因此,我们可以断定,rm big 所需要的时间要远大于rm large 。 因为big只有一个硬链接,我们在rm后操作系统发现没有filename引用该文件,操作系统需要去回收空间。 但large不一样。 操作系统在unlink large后发现还有一个硬链接引用,所以不用去回收空间。 测试如下:

[root@node1 test]# time rm -f big

real	0m1.753s
user 0m0.000s
sys 0m1.750s
[root@node1 test]# time rm -f large real 0m0.001s
user 0m0.000s
sys 0m0.001s

  

linux 的硬链接与软连接的更多相关文章

  1. 【Linux学习】Linux文件系统4—Linux文件硬链接与软连接

    Linux文件系统4-Linux文件硬链接与软连接 inode:索引节点 (连接文件)link 一.文件硬链接 1.Linux文件系统中,inode只相同的文件是硬链接文件 2.不同文件名,inode ...

  2. Linux的硬链接、软连接与拷贝

    Linux链接分两种,一种被称为硬链接(Hard Link),另一种被称为符号链接(Symbolic Link).硬链接:创建一个与原文件任何信息都相同的目标文件(文件名可能不同,自由设定).硬连接的 ...

  3. Linux硬链接和软连接的区别与总结

    图示软硬链接的区别 有关硬链接的总结 具有相同inode节点号的多个文件互为硬链接文件: 删除硬链接文件或者删除源文件任意之一,文件实体并未被删除: 只有删除了源文件和所有对应的硬链接文件,文件实体才 ...

  4. Linux系统硬链接和软链接介绍

    1.链接的概念 在Linux系统中链接分为硬链接和软连接两种,一种为硬链接,另一种为软连接或符号链接(symbolic Link).ln命令就是创建链接文件的,在默认不带参数的情况下,执行ln命令创建 ...

  5. 理解 Linux 的硬链接与软链接(待研究)

    从 inode 了解 Linux 文件系统 硬链接与软链接是 Linux 文件系统中的一个重要概念,其涉及文件系统中的索引节点 (index node 又称 inode),而索引节点对象是 Linux ...

  6. Linux 的硬链接与软链接

    Linux 的硬链接与软链接    http://www.ibm.com/developerworks/cn/linux/l-cn-hardandsymb-links/    若一个 inode 号对 ...

  7. 理解Linux的硬链接与软链接-转载

    理解Linux的硬链接与软链接 来自:https://www.ibm.com/developerworks/cn/linux/l-cn-hardandsymb-links/index.html

  8. 轻松学习Linux之理解Shell的硬链接与软连接

     大家在学习linux的过程中常常遇到一些模糊且容易混淆的概念比如什么是硬链接和软链接,他们有什么区别?  软连接有点象windows中的快捷方式,连接和目标文件具有相同的节点,而硬连接就好象重新复制 ...

  9. Linux硬链接与软连接

    1.Linux链接概念 Linux链接分两种,一种被称为硬链接(Hard Link),另一种被称为符号链接(Symbolic Link).默认情况下,ln命令产生硬链接. [硬连接]硬连接指通过索引节 ...

随机推荐

  1. 详解Android Activity启动模式

    相关的基本概念: 1.任务栈(Task)   若干个Activity的集合的栈表示一个Task.   栈不仅仅只包含自身程序的Activity,它也可以跨应用包含其他应用的Activity,这样有利于 ...

  2. iOS programming UITableView and UITableViewController

    iOS programming  UITableView and UITableViewController A UITableView displays a single column of dat ...

  3. Objective-C Memory Management Being Exceptional 异常处理与内存

    Objective-C Memory Management    Being Exceptional  异常处理与内存 3.1Cocoa requires that all exceptions mu ...

  4. 阿里云ECS安装sqlserver,本地无法连接问题排查思路

    1. 阿里云控制台-对应的ECS实例的安全组是否添加了响应的端口(1433)可以访问: 2. 服务器-sqlserver服务是否开启: 3. 服务器-sqlserver配置器,对应的端口是否启用,已经 ...

  5. Java泛型中的协变和逆变

    Java泛型中的协变和逆变 一般我们看Java泛型好像是不支持协变或逆变的,比如前面提到的List<Object>和List<String>之间是不可变的.但当我们在Java泛 ...

  6. Android原生方式获取经纬度

    两种定位方式:GPS定位.WiFi定位优劣: 如果项目定位要求较高还是建议使用三方地图库 GPS定位相比Wifi定位更精准且可在无网络情况下使用,但在室内基本暴毙无法使用WiFi定位没有室内外限制也不 ...

  7. 玩一把redis源码(一):为redis添加自己的列表类型

    2019年第一篇文档,为2019年做个良好的开端,本文档通过step by step的方式向读者展示如何为redis添加一个数据类型,阅读本文档后读者对redis源码的执行逻辑会有比较清晰的认识,并且 ...

  8. Linux——网络编程线程池机制

    #include <stdlib.h>#include <pthread.h>#include <unistd.h>#include <assert.h> ...

  9. Jmeter之WebService接口测试

    一.简介  1.JMeter3.2前的版本,可以使用SOAP/XML-RPC Request插件直接进行webservice接口,而3.2后的版本则已经取消了这个接口,需要另外的方法才能进行测试. 2 ...

  10. Java中创建对象的内存图

    所有人都知道面向对象思想,Java中的对象的创建在内存中是如何创建的,传智播客的视频看了一遍,把一些讲解的比较清晰的内容记录下来,方便记忆的更加深刻,Java中创建对象的过程,首先要理解JVM中栈.堆 ...