Ext4预留了一些inode做特殊特性使用,见下表:

inode

Purpose

0

不存在,Ext4中不存在inode 0.

1

存放损坏的数据块链表

2

根目录

3

User quota. 用户quota索引

4

Group quota. 组quota索引

5

Boot loader.

6

Undelete directory. 未删除的目录

7

预留的块组描述符inode. (用于调整inode数目)

8

日志inode索引

9

The "exclude" inode, for snapshots(?)

10

Replica inode, used for some non-upstream feature?

11

第一个非预留的inode,通常是lost+found目录,s_first_ino in the superblock.

root@ubuntu:/mnt/ext4# hexdump -C -s 1445888 -n 256/dev/sdc

/* (Inode 1, 存放损坏的数据链表) */

00161000  0000 00 00 00 00 00 00  e3 9e 2a 53 e3 9e2a 53  |..........*S..*S|

00161010  e39e 2a 53 00 00 00 00  00 00 00 00 00 0000 00  |..*S............|

00161020  0000 00 00 00 00 00 00  00 00 00 00 00 0000 00  |................|

*

00161100

root@ubuntu:/mnt/ext4# hexdump -C -s 1446144 -n 256/dev/sdc

/* (Inode 2, 根目录) */

00161100  ed41 00 00 00 10 00 00  5f 9c 2b 53 47 9c2b 53  |.A......_.+SG.+S|

00161110  479c 2b 53 00 00 00 00  00 00 03 00 08 0000 00  |G.+S............|

00161120  0000 08 00 02 00 00 00  0a f3 01 00 04 0000 00  |................|

00161130  0000 00 00 00 00 00 00  01 00 00 00 61 2100 00  |............a!..|

00161140  0000 00 00 00 00 00 00  00 00 00 00 00 0000 00  |................|

*

00161180  1c00 00 00 58 2e b0 1f  58 2e b0 1f 80 3117 bc  |....X...X....1..|

00161190  e39e 2a 53 00 00 00 00  00 00 00 00 00 0000 00  |..*S............|

001611a0  0000 00 00 00 00 00 00  00 00 00 00 00 0000 00  |................|

*

00161200

root@ubuntu:/mnt/ext4# hexdump -C -s 1446400 -n 256/dev/sdc

/* (Inode 3, user quota) */

00161200  0000 00 00 00 00 00 00  00 00 00 00 00 0000 00  |................|

*

00161300

root@ubuntu:/mnt/ext4# hexdump -C -s 1446656 -n 256/dev/sdc

/* (Inode 4,group quota) */

00161300  0000 00 00 00 00 00 00  00 00 00 00 00 0000 00  |................|

*

00161400

root@ubuntu:/mnt/ext4# hexdump -C -s 1446912 -n 256/dev/sdc

/* (Inode 5,Boot Loader) */

00161400  0000 00 00 00 00 00 00  00 00 00 00 00 0000 00  |................|

*

00161500

root@ubuntu:/mnt/ext4# hexdump -C -s 1447168 -n 256/dev/sdc

/* (Inode 6, 未删除的目录) */

00161500  0000 00 00 00 00 00 00  00 00 00 00 00 0000 00  |................|

*

00161600

root@ubuntu:/mnt/ext4# hexdump -C -s 1447424 -n 256/dev/sdc

/* (Inode 7,预留的用于存放块组描述符的的inode) */

00161600  8081 00 00 00 c0 40 00  e3 9e 2a 53 e3 9e2a 53  |......@...*S..*S|

00161610  e39e 2a 53 00 00 00 00  00 00 01 00 c8 4f00 00  |..*S.........O..|

00161620  0000 00 00 00 00 00 00  00 00 00 00 00 0000 00  |................|

*

00161650  0000 00 00 00 00 00 00  00 00 00 00 66 2100 00  |............f!..|

00161660  0000 00 00 00 00 00 00  00 00 00 00 01 0000 00  |................|

00161670  0000 00 00 00 00 00 00  00 00 00 00 00 0000 00  |................|

00161680  1c00 00 00 00 00 00 00  00 00 00 00 00 0000 00  |................|

00161690  e39e 2a 53 00 00 00 00  00 00 00 00 00 0000 00  |..*S............|

001616a0  0000 00 00 00 00 00 00  00 00 00 00 00 0000 00  |................|

*

00161700

root@ubuntu:/mnt/ext4# hexdump -C -s 1447680 -n 256/dev/sdc

/* (Inode 8,日志索引) */

00161700  8081 00 00 00 00 00 08  e4 9e 2a 53 e4 9e2a 53  |..........*S..*S|

00161710  e49e 2a 53 00 00 00 00  00 00 01 00 00 0004 00  |..*S............|

00161720  0000 08 00 00 00 00 00  0a f3 02 00 04 0000 00  |................|

00161730  0000 00 00 00 00 00 00  ff 7f 00 00 00 8008 00  |................|

00161740  ff7f 00 00 01 00 00 00  ff ff 08 00 00 0000 00  |................|

00161750  0000 00 00 00 00 00 00  00 00 00 00 00 0000 00  |................|

*

00161780  1c00 00 00 00 00 00 00  00 00 00 00 00 0000 00  |................|

00161790  e49e 2a 53 00 00 00 00  00 00 00 00 00 0000 00  |..*S............|

001617a0  0000 00 00 00 00 00 00  00 00 00 00 00 0000 00  |................|

*

00161800

root@ubuntu:/mnt/ext4# hexdump -C -s 1447936 -n 256/dev/sdc

/* (Inode 9) */

00161800  0000 00 00 00 00 00 00  00 00 00 00 00 0000 00  |................|

*

00161900

root@ubuntu:/mnt/ext4# hexdump -C -s 1448192 -n 256/dev/sdc

/* (Inode 10) */

00161900  0000 00 00 00 00 00 00  00 00 00 00 00 0000 00  |................|

*

00161a00

root@ubuntu:/mnt/ext4# hexdump -C -s 1448448 -n 256/dev/sdc

/* (Inode 11,第一个非预留的inode,通常是lost+found,s_first_ino in the superblock) */

00161a00  c041 00 00 00 40 00 00  e3 9e 2a 53 e3 9e2a 53  |.A...@....*S..*S|

00161a10  e39e 2a 53 00 00 00 00  00 00 02 00 20 0000 00  |..*S........ ...|

00161a20  0000 08 00 00 00 00 00  0a f3 01 00 04 0000 00  |................|

00161a30  0000 00 00 00 00 00 00  04 00 00 00 62 2100 00  |............b!..|

00161a40  0000 00 00 00 00 00 00  00 00 00 00 00 0000 00  |................|

*

00161a80  1c00 00 00 00 00 00 00  00 00 00 00 00 00 0000  |................|

00161a90  e39e 2a 53 00 00 00 00  00 00 00 00 00 0000 00  |..*S............|

00161aa0  0000 00 00 00 00 00 00  00 00 00 00 00 0000 00  |................|

*

00161b00

root@ubuntu:/mnt/ext4#

[ext4]06 磁盘布局 - 特殊inode的更多相关文章

  1. [ext4]07 磁盘布局 - 块/inode分配策略

    Ext4系统从设计上就认为数据局部性是文件系统的文件系统的一个理想品质. 在机械硬盘上,相关联的数据存放在相近的blocks上,可以使得在访问数据时减少磁头驱动器的移动距离,从而加快IO访问. 在SS ...

  2. [ext4]04 磁盘布局 - Meta Block Groups

    Meta Block Groups,可以翻译为元块组集. 如果不采用Meta Block Groups特性,在每个冗余备份的超级块的后面是一个完整的(包含所有块组描述符的)块组描述符表的备份.如前所述 ...

  3. [ext4]010 磁盘布局 - 如何查找inode的磁盘位置

    在linux系统中,任何一个文件,都有一个inode与其对应,也就是说,在一个文件系统中,一个文件都有唯一的ino来标示他,那么在ext4系统中,ino是如何确定的哪? 当我们新创建的文件或目录时,会 ...

  4. [ext4]03 磁盘布局 – Flexible group分析

    Flexible Block Groups (flex_bg),我称之为"弹性块组",是EXT4文件系统引入的一个feature. 所谓Flexible Block Groups, ...

  5. [ext4]08 磁盘布局 - CheckSums

    从2012年开始,Ext4和jbd2的元数据中都开始加入checksums.特性标识是metadata_csum.Checksum算法是在super_block中指定: struct ext4_sup ...

  6. [ext4]05 磁盘布局 - 延迟块组初始化

    延迟块组初始化,Ext4的新特性.如果对应的特性标识uninit_bg置位,那么inode bitmap和inode tables就不会初始化. 延迟块组初始化特性特性可以减少格式化耗时. 延迟块组初 ...

  7. [ext4]09 磁盘布局 - superblock备份机制

    如果sparse_super特性flag被设置(即开启了sparse_super特性),那么super_block和组描述符的副本只会保存在group索引为0或3.5.7的整数幂. 如果没有设置spa ...

  8. [ext4]01 磁盘布局 - block分析

    ext4文件系统最基本的分配单元是"block"(块). block是由一组连续的sectors来组成,其大小介于1k~4K之间,当然不可能是任意值,只能是2的整数次幂个secto ...

  9. [ext4]磁盘布局 - inode bitmap & table

    在[磁盘布局 group部分]已经介绍过ext4的整体布局,其中存在两个与inode有关的名称:inode bitmap和inode table. Inode bitmap,用于表示inode tab ...

随机推荐

  1. .Net Core迁移到MSBuild平台(二)

    一.前言 在上一篇文章.Net Core迁移到MSBuild的多平台编译问题中,简单的讲了下新的项目配置文件中的节点配置,这篇我将用一些例子来详细讲下从project.json迁移到msbuild过程 ...

  2. python + selenium <一>

    python 安装 python 下载地址: http://python.org/getit/ ez_setup.py 下载地址: https://pypi.python.org/packages/s ...

  3. CoreAnimation 视觉效果

    CoreAnimation 视觉效果 CoreAnimation 目录 博客园MakeDown支持不佳,如有需要请进GitHub iPhone手机的视觉效果是十分优秀的,因此作为iOS工程师一定要对其 ...

  4. 【方法】如何限定IP访问Oracle数据库

    [方法]如何限定IP访问Oracle数据库 1.1  BLOG文档结构图 1.2  前言部分 1.2.1  导读和注意事项 各位技术爱好者,看完本文后,你可以掌握如下的技能,也可以学到一些其它你所不知 ...

  5. 微信JS初始化--微信JS系列文章(一)

    概述 微信JS的使用方法,官方文档已经描述得比较清楚了,这里我就不重复介绍了,本文意在提供现成的代码,供大家快速迭代开发,以及补充一下官方文档描述得不够清楚的地方,避免大家踩相同的坑. 微信JS初始化 ...

  6. 新手向:Java基础知识

    Java 接口 接口(英文:Interface),在JAVA编程语言中是一个抽象类型,是抽象方法的集合,接口通常以interface来声明.一个类通过继承接口的方式,从而来继承接口的抽象方法. 接口并 ...

  7. Unity 3D Framework Designing(3)——构建View和ViewModel的生命周期

    > 对于一个View而言,本质上是一个MonoBehaviour.它本身就具备生命周期这个概念,比如,Awake,Start,Update,OnDestory等.这些是非常好的方法,可以让开发者 ...

  8. Error--解决使用Application Loader提交ipa包审核时的报错:ERROR ITMS-90168: "The binary you uploaded was invalid."

    在提交iTunes Connect审核时,使用Application Loader提交ipa包时报错:ERROR ITMS-90168: "The binary you uploaded w ...

  9. PRINCE2认证

    PRINCE是PRoject IN Controlled Environment(受控环境下的项目管理)的简称. PRINCE2描述了如何以一种逻辑性的.有组织的方法,按照明确的步骤对项目进行管理.它 ...

  10. 虚拟机Linux 的一些基础命令和注释

    cd命令 cd    ==回到初始,主目录 cd -  ==回到上一级目录交替 cd ~ ==回到root家目录 cd .  ==当前目录 cd .. ==进入上一级目录 ls命令 ls     == ...