软链接和硬链接的区别

      什么是链接文件? 使用windows的朋友们应该会经常接触到快捷方式吧!它也就是能让我们快速的打开一个目标应用程序,文件,或者文件夹来使我们的操作更加快捷。那么下面我们就来简单聊聊linux上的“链接文件”吧!

 

 

    

      linux上什么是链接文件呢?这里我们通过一条命令来查看一下:

示例:

[root@Echo /]# ll lib

lrwxrwxrwx. 1 root root 7 Oct  8 21:23 lib -> usr/lib

      lrwxrwxrwx这里开头的l”代表链接文件,比如说,如果这里是“”就是一个普通文件,“d”是一个目录文件,这里就不详细解释linux上的文件类型了。

   其实在linux上链接文件分为2种,一种是硬链接( hard links)另外一种是软连接或者符号链接(symbolic links),那我们先说说硬链接吧。

         

   说到硬链接,这里我们还要普及一个知识点,那是就inode(节点),其实文件是由元数据(metadata)和数据(data)组成,元数据也就是包括文件名,大小,属性等,inode就是记录文件的属性的,一个文件会占用一个inode,那么文件的内容由inode中记录的信息去查找,好了,知道了这些,我们就能更容易了解硬链接了。

示例:

[root@Echo test]# ln /etc/issue ./

[root@Echo test]# ll -i /etc/issue /test/issue

134299792 -rw-r–r–. 2 root root 79 Oct  8 21:36 /etc/issue

134299792 -rw-r–r–. 2 root root 79 Oct  8 21:36 /test/issue

让我们来看看这个示例,通过命令我们看出了,做完硬链接之后的两个文件的确是指向同一个inode,上面说的文件的内容是由inode中的记录的信息查找的,所以这两个文件的大小都是一样的,还有文件被链接的次数是每做一次硬链接就会增长一次,但是磁盘空间与inode的数目都不会改变

  不能跨文件系统:

       因为不同的文件系统都会有自己不同的inode划分,所以硬链接不能跨文件系统。

  不能链接目录;

       虽然说man手册里有硬链接目录的命令,但是连管理员使用都拒绝了,所以现在对目录硬链接还不是很支持。

   软连接(其实这里说是快捷方式才差不多),相对与硬链接,软连接就很好理解了,它就是在创建一个独立的文件,而这个文件会让数据的读取指向它链接的那个文件的文件名,由于只是用文件来指向作为操作,那么当源文件被删,改名或者移动到其他位置,软连接打不开了,会一直闪烁。

示例:

[root@Echo test]# ln -s /etc/passwd ./

[root@Echo test]# ll -i /etc/passwd /test/passwd

134670035 -rw-r–r– 1 root root 2074 Oct 19 19:53 /etc/passwd

      379 lrwxrwxrwx 1 root root   11 Oct 19 21:46 /test/passwd -> /etc/passwd

上面的示例发现;我们同硬链接做对比,链接文件的颜色是浅蓝色的,而且inode是不一样的和我们上面说的一样,还有你看下链接文件的大小是不是被链接文件的绝对路径的字符数“/etc/passwd”是不是11个字符,在这里说明一下,“–>”指向的就是被链接的文件名,还有软连接的文件会占用磁盘空间和inode,建议在创建软连接的时候指相对路径,而硬链接来说相对,绝对路径都行。当然相对于硬链接来说是它可以对目录进行链接,也可以跨分区。

那么下面就简单说一下命令的用法:

硬链接:

ln filename [linkname]

软链接:

ln -s filename [linkname]

 

其他选项:

-b–backup:删除,覆盖目标文件之前的备份;

-d-F——directory:建立目录的硬连接;

-f——force:强行建立文件或目录的连接,不论文件或目录是否存在;

-i——interactive:覆盖既有文件之前先询问用户;

       -n–no-dereference:把符号连接的目的目录视为一般文件

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

(0)
EchoEcho
上一篇 2016-10-19
下一篇 2016-10-19

相关推荐

  • Linux下编译内核

                           Linux下编译内核 内核编译: 编译内核就是把内核的相关文件重新生成。   内核编译前期准备: Linux kernel下载网址:https://www.kernel.or…

    系统运维 2016-09-21
  • IP地址之IPv6

    一、IPv6概述   目前使用的IP地址都是IPv4版本,之所以开发出IPv6版本主要是基于以下原因:     1、IPv4地址空间不足,分配不合理;     2、IPv4头部太过于复杂;     3、使用IPv4使得路由器及主机配置复杂;     4、对于IPv4重新…

    Linux干货 2016-01-13
  • 三次握手和四次挥手

    今天来聊一下事实标准协议TCP/IP中传输层里TCP协议中,主机与服务器建立连接时的三次握手,和断开连接时的四次挥手。 本博文分两部分介绍,    一:状态详解    二:三次握手和四次挥手状态介绍 这里总共涉及到十种状态,其实总共有十一种状态,接下来分别介绍一下它们; 一:状态详解 CLOSED:关闭—&…

    2017-09-01
  • rpm与yum的简单命令

                                  …

    Linux干货 2017-04-18
  • N25-第11周博客作业

    1、详细描述一次加密通讯的过程,结合图示最佳。 第一步:他们需要实现协商好对称加密算法,单向加密算法,公钥加密算法,交换公钥等。 第二步:B用户想要将数据传给A,首先需要使用单向加密算法取出数据的特征码,并用自己的私钥对这段特征码进行加密(数字签名),B用户生成临时对称密钥,并用对称密钥加密整段数据,B用户使用 A用户的公钥加密一次性对称密钥,附加在整段数据…

    Linux干货 2017-05-21
  • Redis数据库安全手册

    Redis是一个高性能的key-value数据库,这两年可谓火的不行。而Redis的流行也带来一系列安全问题,不少攻击者都通过Redis发起攻击。本文将讲解这方面的内容,包括Redis提供的访问控制和代码安全问题,以及可以由恶意输入和其他类似的手段触发的攻击。 Redis通用安全模块 Redis被设计成只能由可信环境的可信机器访问。这意味着将它直接暴露在互联…

    2015-03-12