inode概念总结

一、inode

 inode是类UNIX系统上文件系统中的一种数据结构。数据在磁盘上存储是按扇区存放的,几个扇区组成一个块(block),操作系统为高效读取磁盘上的数据,按block来读取。而数据存放的block的地址就包含在inode里。

二、inode的存储信息

 每个inode保存一个文件系统对象(目录,文件,管道,软连接,socket,设备文件等)的元数据信息,如下

  • 字节为单位表示的文件大小。

  • 设备ID,标识容纳该文件的设备。

  • 文件所有者的User ID。

  • 文件的Group ID

  • 文件的模式(mode),确定了文件的类型,以及它的所有者、它的group、其它用户访问此文件的权限。

  • 额外的系统与用户标志(flag),用来保护该文件。

  • 3个时间戳,记录了inode自身被修改(ctimeinode change time)、文件内容被修改(mtimemodification time)、最后一次访问(atimeaccess time)的时间。

  • 1个链接数,表示有多少个硬链接指向此inode。

  • 文件系统存储位置的指针。通常是1K字节或者2K字节的存储容量为基本单位。

三、inode的作用

 操作系统按inode的编号对文件进行识别,在同一文件系统内的inode的编号是唯一的。当我们打开一个文件的时候,系统按照directory里inode编号与文件名对照关系,把文件名转换为inode编号,再根据inode编号对应的inode信息里指向的block地址来打开文件。这一特性使得在Linux上可以更新一个正在打开的文件,因为更新的文件由一个新的inode来指向,与系统正在使用的原inode不发生冲突,只是directory里的对照关系发生更改,当再次打开次文件时,系统即打开更新后的文件。

inode.png

  • inode不足时,再往文件系统上存放数据也会报存储空间不足的错误

    这是有可能某目录下已产生大量小文件,占用了大量inode

  • inode中存储的block的地址数量和block块的大小限制了一个文件系统最大单个文件大小

四、查看inode方法

[root@centos7 ~]# ll -i /root          #查看文件inode编号,第一列为inode编号
total 4
206271991 -rw-------. 1 root root 1598 Jul 21 11:40 anaconda-ks.cfg
  103963 drwxr-xr-x. 2 root root    6 Jul 21 11:42 Desktop
  103965 drwxr-xr-x. 2 root root    6 Jul 21 11:42 Documents
 70662524 drwxr-xr-x. 2 root root    6 Jul 21 11:42 Downloads
 70662525 drwxr-xr-x. 2 root root    6 Jul 21 11:42 Music
138238502 drwxr-xr-x. 2 root root    6 Jul 21 11:42 Pictures
206272017 drwxr-xr-x. 2 root root    6 Jul 21 11:42 Public
138238501 drwxr-xr-x. 2 root root    6 Jul 21 11:42 Templates
206272018 drwxr-xr-x. 2 root root    6 Jul 21 11:42 Videos

[root@centos7 ~]# df -i                #查看文件系统inode占用情况
Filesystem       Inodes  IUsed    IFree IUse% Mounted on
/dev/sda2      41943040 138671 41804369    1% /
devtmpfs         229955    389   229566    1% /dev
tmpfs            233586     10   233576    1% /dev/shm
tmpfs            233586    590   232996    1% /run
tmpfs            233586     13   233573    1% /sys/fs/cgroup
/dev/sda5      20971520     15 20971505    1% /testdir
/dev/sda1        204800    330   204470    1% /boot
/dev/sr0              0      0        0     - /run/media/root/CentOS 7 x86_64
tmpfs            233586      1   233585    1% /run/user/1001
tmpfs            233586     17   233569    1% /run/user/42
tmpfs            233586      1   233585    1% /run/user/0

五、硬连接与软链接

 硬连接的创建实质为同一物理文件起多个名字,都指向同一inode,所以不可以跨文件系统建立,也不能对目录建立硬连接。

 软链接的创建会产生新文件,占用一个inode,指向的是文件名,软连接建立可跨文件系统,可对目录建立。

  • 创建方法

ln TARGET LINK_NAME      #创建硬连接

ln -s TARGET LINK_NAME   #创建软连接

注:创建软连接时,TARGET如是相对路径,则为LINK_NAME上级目录的相对路径

ln -s Videos/movie /root/movie

则创建了软链接文件/root/movie 指向目录/root/Videos/movie 

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

(1)
cutemsyucutemsyu
上一篇 2016-08-05 16:13
下一篇 2016-08-05 16:13

相关推荐

  • 用户权限以及组权限作业

    1、在/data/testdir里创建的新文件自动属于g1组,组g2的成员如:alice能对这些新文件有读写权限,组g3的成员如:tom只能对新文件有读权限,其它用户(不属于g1,g2,g3)不能访问这个文件夹。 [root@localhost testdir]# mkdir -p /data/testdir [roo…

    Linux干货 2016-08-08
  • Linux部分命令及使用

    Linux部分命令解释及使用 ASCII 信息交换码  GB2312 big5 UTF-8 字符集 乱码问题 生产环境中最常见故障  字符集格式设置不一致 查看系统版本  cat /etc/redhat-release  $() “&nb…

    2017-04-09
  • Linux权限基本介绍,管理

     Linux权限机制采用UGO模式。其中 u(user)表示所属用户、g(group)表示所属组、o(other)表示除了所属用户、所属组之外的情况。 u、g、o 都有读(read)、写(write)、执行(excute) 三个权限,所以UGO模式是三类九种基本权限。         用命令 ls …

    Linux干货 2017-07-22
  • 马哥教育网络班20期+第2周课程练习

    1、Linux上的文件管理类命令有:cp复制, mv剪切, rm移除 使用方法: cp复制  cp [OPTION]… [-T] SOURCE DEST  常用选项: -i:交互式 -r: 递归复制目录及内部的所有内容 -a: 归档 演示: SRC是文件,会将/etc/fstab 中内容覆盖到/bin/po…

    Linux干货 2016-06-23
  • linux初期了解

    计算机的组成及其功能 计算机有运算器,控制器,存储器,输出设备和输入设备组成: 1.运算器:运算器又称算术逻辑单元(Arithmetic Logic Unit简称ALU)。它是计算机对数据进行加工处理的部件,包括算术运算2.控制器:控制器负责从存储器中取出指令,并对指令进行译码 3.存储器:存储器是计算机记忆或暂存数据的部件。 4.输入设备:输入设备是给计算…

    Linux干货 2016-10-30
  • Linux中实现java和c语言打印Hello world小程序

    1、C语言实现 先确认linux系统中是否gcc编译器,可以通过rpm -q gcc查询系统已经安装gcc软件包,如果没有安装可以到系统自带光盘里面安装相应的安装包软件。 使用rpm -ivh gcc-4.8.5-4.el7.x86_64.rpm安装编译器,安装后再查询确认已经成功 环境准备好了,我们就可以编写C语言的代码了,我们可以使用vim编辑器编写第一…

    Linux干货 2016-08-26