不同 ext4 分区之间的文件系统块大小不同

不同 ext4 分区之间的文件系统块大小不同

我们有基于 BBB 的定制板,具有 256MB RAM 和 4GB eMMC,

我使用下面的代码对其进行了分区,

parted --script -a optimal /dev/mmcblk0 \
  mklabel gpt \
  mkpart primary 128KiB 255KiB \
  mkpart primary 256KiB 383KiB \
  mkpart primary 384KiB 511KiB \
  mkpart primary 1MiB 2MiB \
  mkpart primary 2MiB 3MiB \ 
  mkpart primary 3MiB 4MiB \
  mkpart primary 4MiB 5MiB \ 
  mkpart primary 5MiB 10MiB \
  mkpart primary 10MiB 15MiB \
  mkpart primary 15MiB 20MiB \
  mkpart primary 20MiB 21MiB \
  mkpart primary 21MiB 22MiB \
  mkpart primary 22MiB 23MiB \
  mkpart primary 23MiB 28MiB \
  mkpart primary ext4 28MiB 528MiB \
  mkpart primary ext4 528MiB 1028MiB \
  mkpart primary ext4 1028MiB 1128MiB \
  mkpart primary ext4 1128MiB 1188MiB \
  mkpart primary ext4 1188MiB 2212MiB \
  mkpart primary ext4 2212MiB 2603MiB \
  mkpart primary ext4 2603MiB 2639MiB \
  mkpart primary ext4 2639MiB 100% \

然后使用以下命令格式化文件系统分区

mkfs.ext4 -j -L $LABEL $PARTITION

现在,当我使用une2fs读取文件系统块大小时,我看到小于1GiB的分区和大于或等于1GiB的分区的不同值。

# tune2fs -l /dev/mmcblk0p15  | grep Block
Block count:              512000
Block size:               1024
Blocks per group:         8192
# 
# 
# tune2fs -l /dev/mmcblk0p16  | grep Block
Block count:              512000
Block size:               1024
Blocks per group:         8192
# 
# 
# tune2fs -l /dev/mmcblk0p19  | grep Block
Block count:              262144
Block size:               4096
Blocks per group:         32768
# tune2fs -l /dev/mmcblk0p22  | grep Block
Block count:              1191936
Block size:               4096
Blocks per group:         32768

我无法理解为什么块大小不同。此外,mke2fs.conf 仅具有所有默认值,并且提到的块大小为 4096。

[defaults]
    base_features = sparse_super,filetype,resize_inode,dir_index,ext_attr
    default_mntopts = acl,user_xattr
    enable_periodic_fsck = 0
    blocksize = 4096
    inode_size = 256
    inode_ratio = 16384

[fs_types]
    ext3 = {
        features = has_journal
    }
    ext4 = {
        features = has_journal,extent,huge_file,flex_bg,uninit_bg,dir_nlink,extra_isize
        auto_64-bit_support = 1
        inode_size = 256
    }
    ext4dev = {
        features = has_journal,extent,huge_file,flex_bg,uninit_bg,dir_nlink,extra_isize
        inode_size = 256
        options = test_fs=1
    }
    small = {
        blocksize = 1024
        inode_size = 128
        inode_ratio = 4096
    }
    floppy = {
        blocksize = 1024
        inode_size = 128
        inode_ratio = 8192
    }
    big = {
        inode_ratio = 32768
    }
    huge = {
        inode_ratio = 65536
    }
    news = {
        inode_ratio = 4096
    }
    largefile = {
        inode_ratio = 1048576
        blocksize = -1
    }
    largefile4 = {
        inode_ratio = 4194304
        blocksize = -1
    }
    hurd = {
         blocksize = 4096
         inode_size = 128
    }

有人可以解释/建议文档/提示为什么不同分区的块大小不同?

答案1

正如@derobert 在评论中提到的。

mkfs.ext4/mke2fs 引用/etc/mke2fs.conf并格式化分区。

mke2fs如果没有明确提及,则根据分区大小选择块大小。在mke2fs中读取-b block-sizeand-T usage-type手册页对于相同的。

因此,当分区大小小于 512MB 时,请按照文件中的以下设置mkfs.ext4对其进行格式化。smallmke2fs.conf

 small = {
        blocksize = 1024
        inode_size = 128
        inode_ratio = 4096
    }

但是,当分区大小超过 512MBmkfs.ext4或使用from filemke2fs格式化分区时defaultsmke2fs.conf

[defaults]
    base_features = sparse_super,filetype,resize_inode,dir_index,ext_attr
    default_mntopts = acl,user_xattr
    enable_periodic_fsck = 0
    blocksize = 4096
    inode_size = 256
    inode_ratio = 16384

这就是导致我在不同分区中出现不同块大小的原因。

还有一点注意。要获得格式化后获得的 inode 总数,可以计算如下:

Total number of inodes = partition size / inode_ratio
e.g. 
for 500MB partition
total number of inodes = (500 * 1024 * 1024) / 4096
                       = 128000

笔记:我认为我在这里遗漏了一些东西,因为对于上面显示的计算,显示的实际值tune2fs几乎Inode count: 128016匹配但不准确。

相关内容