硬链接与软链接的区别

硬链接与软连接

      

        本文仅用于个人学习参考:

        简单介绍了硬链接与软连接的区别。

        硬链接

        关于硬链接,也就是是说硬盘当中有个文件,在这个文件最初创建的时候有个文件名,由于各种原因,比如说原路径比较难打,我们又创建了一个硬连,放在比较容易找到的位置。

        这一点本人的理解为:来到马哥基地这里有两个大门,左边一个能进来,右边那个也是没问题的,只是左右名字不同罢了。

        硬链接命令语法:

        ln  filename [linkname]

                   filename: [创建出的链接名 ]:

                  linkname:需要被链接的文件

             

        硬链接特点:

        如上边所说,马哥都是同一位马哥,只是称呼不同。

    ]# touch 11.22           /*首先创建一个文件*/
    ]# ln 11.22 22.11        /*然后为该文件创建一个硬链接*/ 
    ]# ls -l                           /*对比原文件与链接文件*/
        total 0
        -rw-r--r-- 2 root root  0 Oct 20 10:28 11.22
        -rw-r--r-- 2 root root  0 Oct 20 10:28 22.11
        drwxr-xr-x 5 root root 31 Oct 20 10:17 kai
  •         在这个图片中可以清楚的看到,原来的文件与我们使用 ln(硬链接)命令创建出来的数据块(硬链接并不生成文件,下边内容为了容易称呼,我说成硬链接文件)除了文件名,其余都是一模一样的。

  •         硬链接只能在同一分区内创建。硬链接不能针对与目录使用。

            与cp的文件相似,不过硬链接文件可以同步更新,就算源文件丢失,硬链接也能访问。

  •         当然,如果源文件与链接文件同时被删除,那么该文件就彻底没了。

 

        软连接

        软连接相当于windows的快捷方式,当源文件丢失,那么快捷方式也会失去作用。

        
        软连接命令语法:

            ln -s filename [linkname]

                               filename: [创建出的链接名 ]:

                              linkname:需要被链接的文件

        软连接特点:

    软链接的须相对路径设定必指定的是针对与目标文件的相对路径,相对路径可以防止源文件地址的改变。

# ln -s ../home/hua/ hua.1

# ls -l
lrwxrwxrwx  1 root root       12 Oct 20 11:29 hua.1 -> ../home/hua/

   

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

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

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

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

  • 软链接可交叉文件系统;

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

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

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

        如上所说如果软连接的原文件被删除,那么相关链接就会死链。

    死链.png

         当然软链接的用户数据也可以是另一个软链接的路径,其解析过程是递归的。但需注意:软链接创建时原文件的路径指向使用相对路径较好。硬链接创建的时候可以指定绝对路径、相对路径,或者直接就不指定了,因为硬链接创建完成之后,就相当于与原文件断绝了关系,原文件位置的改变并不会影响到硬链接。

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

(0)
lyly
上一篇 2016-10-20 11:50
下一篇 2016-10-20 13:09

相关推荐

  • ssh基于密钥的认证及实现

    ssh登录认证方式介绍 大致有以下两种 基于口令的认证这种认证方式就是通过ssh指令以指定用户名、指定端口等信息后,待连接建立完成,需要输入用户名对应的口令来完成认证。一般形如: [root@localhost ~]# ssh -l lantian 192.168.1.201  &nbsp…

    Linux干货 2017-01-05
  • Linux系统终端类型

    引言 终端(Terminal)也称终端设备,是计算机网络中处于网络最外围的设备,主要用于用户信息的输入以及处理结果的输出等。在早期计算机系统中,由于计算机主机昂贵,因此一个主机一般会配置多个终端,这些终端本身不具备计算能力,仅仅承担信息输入输出的工作,运算和处理均由主机来完成,在个人计算机时代,个人计算机可以运行称为终端仿真器的程序来模仿一个终端的工作。 &…

    Linux干货 2016-10-19
  • Linux磁盘管理工具

    挂载mount          挂载:将额外文件系统与根文件系统某现存的目录建立起关联关系,                 进而使得此目录做为其它文件访问入口的行为         &n…

    Linux干货 2016-08-29
  • Homework Week-14 iptables及tcpwraper访问控制

    系统的INPUT和OUTPUT默认策略为DROP; 1、限制本地主机的web服务器在周一不允许访问;新请求的速率不能超过100个每秒;web服务器包含了admin字符串的页面不允许访问;web服务器仅允许响应报文离开本机; iptables -A INPUT -d 192.168.1.101 -p …

    Linux干货 2016-12-05
  • 0809行编辑器sed

    sed :Stream EDitor, 行编辑器  sed是一种流编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有改变,除非你使用重定向存储输出或者使用-i选…

    Linux干货 2016-08-10
  • Linux基础目录名称及功用

    FHS目录规则 Filesystem Hierarchy Standard(文件系统目录标准)的缩写,多数Linux版本采用这种文件组织形式,类似于Windows操作系统中c盘的文件目录,FHS采用树形结构组织文件。FHS定义了系统中每个区域的用途、所需要的最小构成的文件和目录,同时还给出了例外处理与矛盾处理。   FHS定义了两层规范,第一层是,…

    Linux干货 2016-10-30