我想制作 ext2 文件系统。我想将“ number-of-inodes ”选项设置为某个数字。我尝试了几个值:
- 如果-N 99000那么 inode 计数:99552
- 如果-N 3500那么索引节点数:3904
- 如果-N 500那么 inode 数:976
但总是我的价值不一样。为什么?
我这样调用mkfs
sudo mkfs -q -t ext2 -F /dev/sda2 -b 4096 -N 99000 -O none,sparse_super,large_file,filetype
我这样检查结果
$ sudo tune2fs -l /dev/sda2
tune2fs 1.46.5 (30-Dec-2021)
Filesystem volume name: <none>
Last mounted on: <not available>
Filesystem UUID: 11111111-2222-3333-4444-555555555555
Filesystem magic number: 0xEF53
Filesystem revision #: 1 (dynamic)
Filesystem features: filetype sparse_super large_file
Filesystem flags: signed_directory_hash
Default mount options: user_xattr acl
Filesystem state: clean
Errors behavior: Continue
Filesystem OS type: Linux
Inode count: 99552
Block count: 1973720
Reserved block count: 98686
Overhead clusters: 6362
Free blocks: 1967353
Free inodes: 99541
First block: 0
Block size: 4096
Fragment size: 4096
Blocks per group: 32768
Fragments per group: 32768
Inodes per group: 1632
Inode blocks per group: 102
Filesystem created: Thu Apr 6 20:00:45 2023
Last mount time: n/a
Last write time: Thu Apr 6 20:01:49 2023
Mount count: 0
Maximum mount count: -1
Last checked: Thu Apr 6 20:00:45 2023
Check interval: 0 (<none>)
Reserved blocks uid: 0 (user root)
Reserved blocks gid: 0 (group root)
First inode: 11
Inode size: 256
Required extra isize: 32
Desired extra isize: 32
Default directory hash: half_md4
Directory Hash Seed: 61ff1bad-c6c8-409f-b334-f277fb29df54
这个数字没有被忽略,它被四舍五入了。看起来 inode 的空间是按组分配的。在您的输出中查看:
当您请求 99,000 个 inode 时,它不能被 1,632 整除。因此,为确保您获得所需的 inode 数量,该数字已四舍五入为 99,552,可被 1,632 整除。
看起来这个限制可能以某种方式源自块组的数量,其中每个组中的 inode 数量在所有块组中都是统一的。我的猜测是每个块组的 inode 数计算为请求的 inode 数除以块组数,然后四舍五入为整数。请参阅OSDev Wiki 上的 Ext2