​Linux 硬连接与软连接的区别

    Linux 硬连接与软连接的区别


                                1476965794247694.jpg

我们知道文件都有文件名与数据,这在 Linux 上被分成两个部分:用户数据 (user data) 与元数据 (metadata)。用户数据,即文件数据块 (data block),数据块是记录文件真实内容的地方;而元数据则是文件的附加属性,如文件大小、创建时间、所有者等信息。在 Linux 中,元数据中的 inode 号(inode 是文件元数据的一部分但其并不包含文件名,inode 号即索引节点号)才是文件的唯一标识而非文件名。文件名仅是为了方便人们的记忆和使用,系统或程序通过 inode 号寻找正确的文件数据块。图 1.展示了程序通过文件名获取文件内容的过程。

         

image001.jpg

图 1

Inode

    Inode 是liunx 操作系统中的一种数据结构,其本质是结构体,它包含了与各个文件相关的一些重要信息。在linux中创建文件系统时,同时将会创建大量的inode 。通常,文件系统磁盘空间中大约百分之一空间分配给了inode表。

    有时人们使用了一些不同的术语,如inode和索引编号这两个术语非常相似,但他们所指的并不是同样的概念。Inode 指的是数据结构;而索引编号实际上是inode的标示via你好,因此称其inode编号或索引编号。索引编号只是文件相关信息中一项重要的内容。

硬链接

    为解决文件的共享使用,Linux 系统引入了两种链接:硬链接 (hard link) 与软链接(又称符号链接,即 soft link 或 symbolic link)。链接为 Linux 系统解决了文件的共享使用,还带来了隐藏文件路径、增加权限安全及节省存储等好处。若一个 inode 号对应多个文件名,则称这些文件为硬链接。

    硬链接,指通过索引节点来进行链接。在linux的文件系统中,保存在linux 分区中的文件不管是什么类型都给它分配一个编号,称为索引节点号(inode index)。Linux中多文件名指向同一索引节点是存在的。一般这种连接就是硬连接。硬连接的作用是允许一个文件拥有多个有效路径名,这样用户就可以建立硬链接到重要文件,以防止”误删”的功能,其原因如上所述,因为对应的该目录的索引节点有一个以上的链接。只删除一个链接并不影响索引节点本身和其他链接,只有当最后一个链接被删除后,文件的数据块及目录的链接才或被释放。也就是说文件真正删除的条件是与之相关的所有硬连接文件均被删除。

    1、在linux 中硬链接可由命令 link 或 ln 创建。                      

    ln   file1  linkname

    link  file1  linkname

    删除链接 rm linkname    link linkname

2、由于硬链接是有着相同 inode 号仅文件名不同的文件,因此硬链接存在以下几点特性:

        文件有相同的 inode 及 data block;

    只能对已存在的文件进行创建;

    不能交叉文件系统进行硬链接的创建;

    不能对目录进行创建,只可对文件创建;

    删除一个硬链接文件并不影响其他有相同 inode 号的文件。

 

软链接

    软链接与硬链接不同,若文件用户数据块中存放的内容是另一文件的路径名的指向,则该文件就是软连接。软链接就是一个普通文件,只是数据块内容有点特殊。软链接有着自己的 inode 号以及用户数据块(见 图 2.)。

    因此软链接的创建与使用没有类似硬链接的诸多限制:

    软链接有自己的文件属性及权限等;

    可对不存在的文件或目录创建软链接;

    软链接可交叉文件系统;

    软链接可对文件或目录创建;

    创建软链接时,链接计数 i_nlink 不会增加;

    删除软链接并不影响被指向的文件,但若被指向的原文件被删除,则相关软连接被称为死链接(即 dangling link,若被指向路径文件被重新创建,死链接可恢复为正常的软链接)。

1、使用方法

         ln –s  file1  linkfilename

2、软连接的访问

    image002.jpg

                   

 

原创文章,作者:秋季,如若转载,请注明出处:http://www.178linux.com/53225

(0)
秋季秋季
上一篇 2016-10-25 09:46
下一篇 2016-10-25 09:46

相关推荐

  • selinux介绍

    本章内容 SELinux概念启用SELinux管理文件安全标签管理端口标签管理SELinux布尔值开关管理日志查看SELinux帮助 SELinux介绍 SELinux: Secure Enhanced Linux,是美国国家安全局「NSA=The National Security Agency」和SCC(Secure Computing Corporat…

    Linux干货 2016-09-19
  • 使用Openssl构建私有CA

    使用Openssl构建私有CA Openssl是SSL的开源实现,是一种安全机密程序,主要用于提高远程登录访问的安全性。也是目前加密算法所使用的工具之一,功能很强大。     Openssl为网络通信提供安全及数据完整性的一种安全协议,包括了主要的密码算法、常用的密钥和证书封装管理功能(CA)以及SSL协议,并提供了丰…

    Linux干货 2015-10-07
  • iptables学习笔记

    这几学习iptables,踩了一些坑,作下总结。 1、三表 (1)filter:默认表,处理本机数据包,包含input、output和forward (2)nat:处理源或目的IP/端口转换,包含prerouting、postrouting、output (3)mangle:处理高级路由信息,包含prerouting、output、input、forward…

    Linux干货 2016-06-09
  • rpm,yum,编译安装应用详解 (Blog 5)

    rpm, yum, 编译安装全解

    2017-11-27
  • Linux的终端类型

    Linux的终端类型 Linux的终端类型: TTY(虚拟终端,图形终端) 早期的电子计算机的输入设备是穿孔卡片【又称霍列瑞斯式卡(Herman Hollerith)或IBM卡】,用有洞和无洞表示计算机二进制里面的0和1,以此来记录相关信息,但是这种方式很慢。 1986年股票代码被发明,人们通过电报和电传打印机发送实时股票价格,此时teletypewrite…

    Linux干货 2016-10-14
  • linux 学习笔记

    第二周

    Linux干货 2018-03-16