引子

目前,UNIX的文件系统有很多种实现,例如UFS(基于BSD的UNIX文件系统)、ext3、ext4、ZFS和Reiserfs等等。

不论哪一种文件系统,总是需要存储数据。硬盘的最小存储单位是扇区,数据所存储的最小单位则不是扇区,因为用扇区来存储效率就太低了。一个扇区只有512字节,而磁头是一个扇区一个扇区地读取,也就是说,如果文件是10MB,那么为了读这个文件,磁头必须要进行读取20480次。这样效率是极其低下的。

逻辑块

为了提高效率,就有了逻辑块(Block)的概念,也可以叫做数据块。逻辑块是在分区进行文件系统的格式化时所指定的“最小存储单位”,这个最小存储单位是以扇区为基础的,所以逻辑块的大小总是扇区的2的n次方倍。此时,磁头可以一次读取一个块,这样效率可就高了!

逻辑块的规划是很有学问的,并不是越大越好,因为一个逻辑块最多也只能容纳一个文件(在Linux的ext2中),所以如果逻辑块被规划的太大,那么会很浪费磁盘空间。举个例子,如果一个逻辑块为4KB,而有一个文件只有0.1KB大小,而这个小文件仍然要占用一个逻辑块,因此就会浪费3.9KB的空间。

所以,在规划磁盘时,需要考虑到主机的用途。比如BBS主机,由于文章短小,文件较小,那么逻辑块分配的小一点好。如果主机主要用在存储大容量的文件,那么考虑到使用效率,还是逻辑块大一点好!

磁盘的组成

我们可以把一个磁盘分成一个或多个分区。每个分区可以包含一个文件系统。

我们下面要描述一个分层细化的过程,请您集中精力来随我思考:

1 磁盘是由一个一个分区组成的,即磁盘=分区+分区+分区…

2 每一个分区内都有一个文件系统,且一个分区内有且仅有一个文件系统。

3 每个分区内都依次包含这些内容:自举块(也叫引导块),超级块,柱面组0,柱面组1,…柱面组n。即分区=自举块+超级块+柱面组(若干)

4 每个柱面组又包括了这些内容:超级块副本,配置信息,i节点图(记录哪些i节点可用),块位图(记录哪些块是否可用),i节点(许多),数据块(也叫逻辑块)

好了,你应该可以根据1,2,3,4在脑海里构造出一张分层图了,如果你把它画出来,对你记忆i节点的概念会更有好处。

超级块

超级块(superblock)的作用是存储文件系统的大小、空的和填满的块,以及它们各自的总数和其他诸如此类的信息。要使用一个分区来进行数据访问,那么第一个要访问的就是超级块。所以,如果超级块坏了,那磁盘也就基本没救了。

i节点

下面要讲到i节点,就不能不提提Linux的安全性。由于Linux操作系统是一个多用户、多任务的环境,为了保护每个用户所拥有数据的隐密性,就将每个文件分成了两个部分来存储:一个是文件的属性,另一个则是文件的内容。

i节点(iinode)就是用来存储文件的属性的;而数据块(逻辑块)是用来存储文件的内容的!

如果要格式化一个分区,就要指定inode的大小和块的大小才行!更通俗的说,一个ext2文件系统是一定要包括inode表与块区域这两个部分的!

至于块,我在前面提到过,它也叫逻辑块,还叫数据块,它是数据存储的最小单位。

而inode“记录文件属性以及文件内容放置在哪一个块内”的信息,更通俗的说,inode除了包含文件的属性之外,还包括一个指针,这个指针就指向文件内容放置的数据块的位置,好让操作系统可以方便的去读取文件内容。

在inode中一般包括了这样一些文件属性信息:

  • 文件的拥有者和所属用户组;
  • 文件的访问权限设定;
  • 文件的类型;
  • 文件的访问、修改等时间
  • 文件的大小;
  • 文件的各种标志,如SUID和SGID等;
  • 指向文件内容数据块的指针。

一个inode的大小通常为128字节。(在ext4中这个知识将被颠覆,ext4中的inode大小将扩展到256字节)

好,下面就来看看到底我们怎么利用inode来管理文件呢?

目录

先来看看有关目录操作的细节:

如果我们建立了一个目录,那么系统会分配给该目录一个inode和至少一个块。这个inode就记录该目录的相关属性,并将其中的指针指向分配的那个数据块。而所分配的块内则记录了这个目录下的相关文件(和子目录)的关联性,更通俗的说,目录块中存储了一个包括三列的表,三列分别为:inode,文件名或目录名,指向数据块的指针。

我们用vi命令来查看一下一个目录的内容到底是什么:(当然这只是用户看到的,和文件系统的底层实现是不同的。)

" ============================================================================
" Netrw Directory Listing                                        (netrw v109)
"   /rocrocket/PSB/home/git27
"   Sorted by      name
"   Sort sequence: [\/]$,\.h$,\.c$,\.cpp$,\.[a-np-z]$,*,\.info$,\.swp$,\.o$\.obj$,\.bak$
"   Quick Help: <F1>:help  -:go up dir  D:delete  R:rename  s:sort-by  x:exec
" ============================================================================
../
./
.git/
roc.c

双引号开头的是注释部分,而后紧跟着四个项,前两个是任何目录都固有的“上级目录”和“当前目录”,而后是一个隐藏目录.git,最后是一个当前目录下的文件roc.c。可见,一个目录其实也是一个文件,只不过它其中不存储用户数据,而是存储目录下的文件和子目录列表。

如果在Linux中新建一个普通文件,则系统会为该文件分配至少一个inode与相对于该文件大小的块数量。例如,假设一个块为4KB,要建一个100KB的文件,则Linux将分配一个inode与25个块来存储该文件。

有一点要特别!特别!特别!提醒的是:inode本身并不记录文件名,而是记录文件的相关的属性(在上文提到过的那些属性),文件名则记录在目录所属的块区域。正因为这个原因,使得如果Linux读取一个文件的内容,就要先由根目录/获取该文件的上层目录所在的inode,再由该目录所记录的的文件关联性获取该文件的inode,最后通过inode内提供的块指针来获取最终的文件内容。

链接计数

而当谈到链接数的时候,这里我还要提出一些概念和几个规律性的结论:

每个i节点中都存有一个链接计数,其值是指向该i节点的目录项数。

只有当链接技术减少到0时,才可删除该文件(也就是释放该文件占有的数据块)

能够增加链接数的链接为硬链接。

软链接也叫符号链接,它的inode的文件类型是S_IFLNK。它只是存储了另一个文件的路径和名称而已。

任何一个叶目录(不包含任何其他目录的目录)的链接计数总是2,数值2来自于命名该目录的目录项以及在该目录中的.项。

父目录中的每一个子目录都会使该父目录的链接计数增1。

精彩引文

最后给出csdn网上qxp网友的一段关于软链接和硬链接的评论,很不错:

我们知道unix文件大致可以分为这样三部分:目录(文件名),inode   和数据区。

对于复制来说,不仅仅创建了新的目录项(文件名),新的inode,还复制了该文件的所有数据;

而硬连结则仅仅创建了新的目录项,并且在目录项中相应的inode编号被连结到相应的文件的inode编号,同时,该文件的inode引用计数加1;

这样,你删除原来的文件时候,文件数据并不会被删除,因为inode结点引用计数>0,所以,通过硬连结还能继续访问。

换句话说,硬连接使得该文件存在另外一个别名,也就是另外一个入口。

顺便说一下软连结,就是符号连结,其实就相当于是windows下的快捷方式。

创建了一个新的目录项,一个新的inode,只不过数据区里放的是被引用的文件路径和名称。

结尾PS

ps:其实写这篇文章的目的,是为了在另一篇文章中更好的讲解ln命令,到时会给出大家那篇文章的一个链接。

ps2:关于inode和目录的一点优秀评论:一个文件系统维护了一个索引节点的数组,每个文件或目录都与索引节点数组中的唯一的元素对应。每个索引节点在数组中的索引号,称为索引节点号。linux文件系统将文件索引节点号和文件名同时保存在目录中,所以,目录只是将文件的名称和它的索引节点号结合在一起的一张表,目录中每一对文件名称和索引节点号称为一个连接。

参考文献

本文参考《鸟哥的Linux私房菜》和《UNIX高级环境编程》;

更多信息可以查看http://baike.baidu.com/view/1097021.htmhttp://security.zdnet.com.cn/security_zone/2008/1218/1284126.shtml以及上述资料。

over~

转自:http://roclinux.cn/?p=754

ln使用:

ln是linux中一个非常重要命令。它的功能是为某一个文件在另外一个位置建立一个同步的链接,这个命令最常用的参数是-s,具体用法是:

ln -s  源文件 目标文件    -s 是 symbolic的意思。 
例:ln  -s  /lib/lsb   /usr/lj
即:在usr目录下建立指向/lib/lsb目录的lj文件。

当我们需要在不同的目录,用到相同的文件时,我们不需要在每一个需要的目录下都放一个必须相同的文件,我们只要在某个固定的目录,放上该文件,然后在其它的目录下用ln命令链接(link)它就可以,不必重复的占用磁盘空间。例如:ln -s /bin/less /usr/local/bin/less-s 是代号(symbolic)的意思。这里有两点要注意:第一,ln命令会保持每一处链接文件的同步性,也就是说,不论你改动了哪一处,其它的文件都会发生相同的变化;第二,ln的链接有软链接和硬链接两种,软链接就是ln -s ** **,它只会在你选定的位置上生成一个文件的镜像,不会占用磁盘空间,硬链接ln ** **,没有参数-s, 它会在你选定的位置上生成一个和源文件大小相同的文件,无论是软链接还是硬链接,文件都保持同步变化。软链接是可以跨分区的,但是硬链接只能在同一分区内。如果你用ls察看一个目录时,发现有的文件后面有一个@的符号,那就是一个用ln命令生成的文件,用ls -l命令去察看,就可以看到显示的link的路径了当我们需要在不同的目录,用到相同的文件时,我们不需要在每一个需要的目录下都放一个必须相同的文件,我们只要在某个固定的目录,放上该文件,然后在其它的目录下用ln命令链接(link)它就可以,不必重复的占用磁盘空间。例如:ln -s /bin/less /usr/local/bin/less 
注意:

第一,ln命令会保持每一处链接文件的同步性,也就是说,不论你改动了哪一处,其它的文件都会发生相同的变化;

第二,ln的链接又软链接和硬链接两种,软链接就是ln -s ** **,它只会在你选定的位置上生成一个文件的镜像,不会占用磁盘空间,硬链接ln ** **,没有参数-s, 它会在你选定的位置上生成一个和源文件大小相同的文件,无论是软链接还是硬链接,文件都保持同步变化。软链接是可以跨分区的,但是硬链接只能在同一分区内。
第三:目录不能建立硬链接,但可以建立软链接。

怎样让命令全局执行:

原帖由 "rcazy" 发表:
是这样吗 
ln -s /usr/local/sbin/action action
但是不行,请再指点

當然有錯啦...
當你運行時, 它會在你所在的位置, 用軟連結把/usr/local/sbin/action連到此位置上, 並沒有連到全局位置上.
應該 #ln -s /usr/local/sbin/action /bin
但/usr/local/sbin通常都是全局範圍之一.

http://roclinux.cn/?p=752

Linux 硬连接和软连接的原理 (in使用)的更多相关文章

  1. linux ------ 硬连接和软连接(软连接也叫符号连接)

    在Linux的文件系统中,保存在磁盘分区中的文件不管是什么类型都给它分配一个编号,称为索引节点号 (Inode Index).在Linux中,多个文件名指向同一索引节点是存在的.一般这种连接就是硬连接 ...

  2. linux 硬连接与软连接

    1.linux中文件占用一个inode,inode指向文件内容.2.文件名可以认为是一个指针,指向inode.硬连接相当于指针的整体拷贝,并不是对文件内容的拷贝.两个文件名(两个指针)都能修改文件,删 ...

  3. 初窥Linux 之 区分硬连接和软连接

    一.Linux下的两种连接文件及创建方式 在Linux下面的连接文件有两种——软连接和硬连接,虽然都是连接文件,但两者却有很大的区别.一种是类似于Windows的快捷方式功能的文件(或目录),这种连接 ...

  4. Linux文件系统的硬连接和软连接

    title: Linux文件系统的硬连接和软连接 date: 2018-02-06T20:26:25+08:00 tags: ["文件系统"] categories: [" ...

  5. linux中的硬连接和软连接

    linux中的硬连接和软连接 linux中的硬连接和软连接 背景 连接 硬连接 软连接 example reference 背景 linux中的文件主要分3块, - 真正的数据 - 索引节点号(ino ...

  6. 硬连接与软连接,inode与links

    硬连接和软连接,第一感觉就像是window的快捷方式,实则不然 要说硬连接和软连接,那就必须了解inode和block以及分区了 EXT文件系统在创建分区的时候,就划分了两块区域,inode tabl ...

  7. 【Linux】Shell学习笔记之四——文件和目录管理(硬连接和软连接)

    在这节将要学习linux的连接档,在之前用"ls -l" 查看文件属性的命令时, 其中第二个属性是连接数.那么这个连接数是干什么的?这就要理解inode. 先说一下文件是怎么存储的 ...

  8. linux文件的硬连接和软连接

    建立软连接:ln -s 原路径 目标路径 原理示意图: 特点: 1.     相当于win中的快捷方式 2.     删除链接文件,源文件不受影响 3.     删除源文件,链接文件失效 4.     ...

  9. Linux学习笔记之1——文件和目录管理(硬连接和软连接)(连结档,相当于快捷方式)

    在这节将要学习linux的连接档,在之前用"ls -l" 查看文件属性的命令时, 其中第二个属性是连接数.那么这个连接数是干什么的?这就要理解inode. 先说一下文件是怎么存储的 ...

随机推荐

  1. HDU5196--DZY Loves Inversions 树状数组 逆序数

    题意查询给定[L, R]区间内 逆序对数 ==k的子区间的个数. 我们只需要求出 子区间小于等于k的个数和小于等于k-1的个数,然后相减就得出答案了. 对于i(1≤i≤n),我们计算ri表示[i,ri ...

  2. Xcode Build Setting Reference

    https://developer.apple.com/library/mac/documentation/DeveloperTools/Reference/XcodeBuildSettingRef/ ...

  3. Java体系总结

    一.Java SE部分 1.java基础:基础语法:面向对象(重点):集合框架(重点):常见类库API: 2.java界面编程:AWT:事件机制:Swing: 3.java高级知识:Annotatio ...

  4. Javascript 精髓整理篇之二(函数篇)postby:http://zhutty.cnblogs.com

    今天总结的内容是javascript的function, 涉及到function顺便讲讲this. Function 是javascript的函数,也是js的执行单元.函数是JavaScript的一种 ...

  5. UUID.randomUUID()方法介绍

    UUID.randomUUID().toString()是javaJDK提供的一个自动生成主键的方法.UUID(Universally Unique Identifier)全局唯一标识符,是指在一台机 ...

  6. ios开发中各种版本、设备的区分

    设备类型的区分-iphone ,ipad-itouch..... 可以从 UIDevice 的属性 model 得到在现在执行的环境.例子如下: [cpp] view plaincopyprint? ...

  7. speex的基本编码和解码流程

    最近在研究speex的编码和解码流程 之前在IM上用到的都是发语音片段,这个很简单,只需要找到googlecode上gauss的代码,然后套一下就可以用了. 不过googlecode要关闭,有人将他导 ...

  8. LDAP索引及缓存优化

    一.设置索引 索引将查找信息和 Directory Server 条目关联起来. Directory Server支持以下几种索引: 1出现索引 (pres) - 列出了具有特定属性的条目,与属性的值 ...

  9. Windows Bridge for iOS: Let’s open this up

    (原文翻译过来的,原文链接http://blogs.windows.com/buildingapps/2015/08/06/windows-bridge-for-ios-lets-open-this- ...

  10. .NET程序集签名

    强命名程序集的一个好处是防篡改.假如我有一个程序集MyDll.dll,如果我用我自己的私钥进行签名将程序集中的内容进行哈希处理,其他人如果不知道我的私钥的话,就不能篡改我的这个程序集进行某些恶意的行为 ...