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

相关推荐

  • 计算机基础

    计算机基础知识简单介绍

    2018-03-28
  • nginx基本功能学习

    一、NGINX介绍: Nginx 是一个高性能的 Web 和反向代理服务器, 它具有有很多非常优越的特性:            作为 Web 服务器:相比 Apache,Nginx 使用更少的资源,支持更多的并发连接,体现更高的效率,这点使 Nginx 尤其受到虚拟主机提供商的欢迎。能够支持高达 …

    Linux干货 2015-12-19
  • find命令总结

    用途:     find命令用来在文件层级结构中搜索跟条件匹配的文件 语法:     find [OPTIONS] [查找起始路径] [查找条件] [处理动作]     查找起始路径:指定具体搜索起始路径。默认为当前目录  &nb…

    Linux干货 2016-09-19
  • linux发展简史

    前言 为什么要写这么一篇文章呢?我发现我虽然知道linux的一些知识,却不知道linux方面的历史,所以今天写一篇关于linux方面历史的文章,用来总结这段时间自己所学习到的关于linux的历史与linux的知识。关于说起linux的历史,就不得不介绍计算机的历史,与其他相关操作系统的一些历史,所以本文中的会简单介绍Linux与其他操作系统的关系。主要讲li…

    Linux干货 2017-02-16
  • 8-2 作业

    8-2作业     1.在/data/testdir里创建的新文件自动属于g1组,组g2的成员如:alice能对这些新文件有读写权限,组g3的成员如:tom只能对新文件有读权限,其它用户(不属于g1,g2,g3)不能访问这个文件夹。 2.创建组sales,gid 3000,passwd:centos,sales admins:user2。…

    Linux干货 2016-08-05
  • 初识SElinux

    一、SElinux(Secure Enhanced Linux):安全增强的Linux        SElinux是一个在内核中实践的强制访问控制(MAC)安全性机制,由美国国家安全局NSA(The National Security Agency)和SCC(Secure Computing Co…

    Linux干货 2016-09-15