[ext4]06 磁盘布局 - 特殊inode
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的更多相关文章
- [ext4]07 磁盘布局 - 块/inode分配策略
Ext4系统从设计上就认为数据局部性是文件系统的文件系统的一个理想品质. 在机械硬盘上,相关联的数据存放在相近的blocks上,可以使得在访问数据时减少磁头驱动器的移动距离,从而加快IO访问. 在SS ...
- [ext4]04 磁盘布局 - Meta Block Groups
Meta Block Groups,可以翻译为元块组集. 如果不采用Meta Block Groups特性,在每个冗余备份的超级块的后面是一个完整的(包含所有块组描述符的)块组描述符表的备份.如前所述 ...
- [ext4]010 磁盘布局 - 如何查找inode的磁盘位置
在linux系统中,任何一个文件,都有一个inode与其对应,也就是说,在一个文件系统中,一个文件都有唯一的ino来标示他,那么在ext4系统中,ino是如何确定的哪? 当我们新创建的文件或目录时,会 ...
- [ext4]03 磁盘布局 – Flexible group分析
Flexible Block Groups (flex_bg),我称之为"弹性块组",是EXT4文件系统引入的一个feature. 所谓Flexible Block Groups, ...
- [ext4]08 磁盘布局 - CheckSums
从2012年开始,Ext4和jbd2的元数据中都开始加入checksums.特性标识是metadata_csum.Checksum算法是在super_block中指定: struct ext4_sup ...
- [ext4]05 磁盘布局 - 延迟块组初始化
延迟块组初始化,Ext4的新特性.如果对应的特性标识uninit_bg置位,那么inode bitmap和inode tables就不会初始化. 延迟块组初始化特性特性可以减少格式化耗时. 延迟块组初 ...
- [ext4]09 磁盘布局 - superblock备份机制
如果sparse_super特性flag被设置(即开启了sparse_super特性),那么super_block和组描述符的副本只会保存在group索引为0或3.5.7的整数幂. 如果没有设置spa ...
- [ext4]01 磁盘布局 - block分析
ext4文件系统最基本的分配单元是"block"(块). block是由一组连续的sectors来组成,其大小介于1k~4K之间,当然不可能是任意值,只能是2的整数次幂个secto ...
- [ext4]磁盘布局 - inode bitmap & table
在[磁盘布局 group部分]已经介绍过ext4的整体布局,其中存在两个与inode有关的名称:inode bitmap和inode table. Inode bitmap,用于表示inode tab ...
随机推荐
- Vuex 模块化实现待办事项的状态管理
前言 在vue里,组件之间的作用域是独立的,父组件跟子组件之间的通讯可以通过prop属性来传参,但是在兄弟组件之间通讯就比较麻烦了.比如A组件要告诉一件事给B组件,那么A就要先告诉他们的爸组件,然后爸 ...
- 安装rabbitmq以及集群配置
前言: (一些有用没用的唠叨,反正看了也不少肉,跳过也没啥) 情况是这样的:虚拟机.CentOS 6.5.免编译包安装rabbitmq集群,可不用连外网. 我原计划是安装在虚拟机上wyt1/wyt2/ ...
- ehcache 使用笔记
要想使用 java 的本地缓存,可以考虑用 ehcache,或者 guava. guava 更高端一点,可以自动定时刷新.我选择了 ehcache. 在 spring 中是集成了 ehcache 的. ...
- R语言数据分析利器data.table包 —— 数据框结构处理精讲
R语言data.table包是自带包data.frame的升级版,用于数据框格式数据的处理,最大的特点快.包括两个方面,一方面是写的快,代码简洁,只要一行命令就可以完成诸多任务,另一方面是处理 ...
- angularjs fileUpload
文件上传一直是我不熟悉的地方,<a href='https://github.com/nervgh/angular-file-upload/wiki/Module-API'>官网解释的例子 ...
- 实现Unity编辑器模式下的旋转
最近在做一个模型展示的项目,我的想法是根据滑动屏幕的x方向差值和Y方向的差值,来根据世界坐标下的X轴和Y轴进行旋转,但是实习时候总是有一些卡顿.在观察unity编辑器下的旋转之后,发现编辑器下的旋转非 ...
- BootStrap入门教程 (三)
本文转自 http://www.cnblogs.com/ventlam/archive/2012/06/05/2524966.html 上讲回顾:Bootstrap的基础CSS(Base CSS)提供 ...
- reactjs Uncaught TypeError: Cannot read property 'location' of undefined
reactjs Uncaught TypeError: Cannot read property 'location' of undefined reactjs 路由配置 怎么跳转 不成功 国内搜索引 ...
- 开发Nagios监控passwd文件插件
第一步:开发脚本 [root@Admin libexec]# pwd /usr/local/nagios/libexec [root@Admin libexec]# cat check_passwd ...
- 使用Yeoman generator来规范工程的初始化
前言 随着开发团队不断发展壮大,在人员增加的同时也带来了协作成本的增加:业务项目越来越多,类型也各不相同.常见的类型有基础组件.业务组件.基于React的业务项目.基于Vue的业务项目等等.如果想要对 ...