Почему каждый каталог имеет размер 4096 байт (4 К)?

У меня такая же проблема, и, похоже, она уже появилась как ошибка. Вы можете отметить, что это влияет на вас, чтобы увеличить его значение.

В качестве обходного пути я рекомендую открыть PDF-файлы с помощью Document Viewer / Evince следующим образом: Перейти к Edit → Preferences → Applications , найдите «pdf» и выберите Use Document Viewer:

С файлом открывается другое окно - но Evince очень быстрый и легкий, поэтому вы не столкнетесь с серьезной производительностью потери.

, как сообщается, уже как ошибка

1
задан 9 March 2018 в 13:57

2 ответа

Чтобы понять это, вам лучше иметь базовые знания о следующей (файловой системе):

inode (содержит атрибуты файлов, метаданные файла, структуру указателя) (можно считать таблицей с двумя столбцами, именем файла и его inode, inode указывает на исходные блоки данных в блочном устройстве) (только специальный файл, контейнер для других имен файлов). Он содержит массив имен файлов и номеров индексов для каждого имени файла. отношения между родителями и дочерними элементами.) символическая ссылка VS жесткая ссылка dentry (записи в каталоге) ...

В типичной файловой системе ext4 (что большинство людей используют) размер по умолчанию inode составляет 256 байт , размер блока составляет 4096 байт.

Каталог - это просто специальный файл, который содержит массив имен файлов и номеров inode. Когда каталог был создан, файловая система выделяла 1 inode в каталог с именем «filename» (фактически имя dir). Индед указывает на один блок данных (минимальные служебные данные), который составляет 4096 байт. Вот почему вы видите 4096 / 4.0K при использовании ls.

Вы можете получить информацию, используя tune2fs & amp; dumpe2fs.

Пример

root@ubuntu:~# tune2fs -l /dev/ubuntu/root 
tune2fs 1.42 (29-Nov-2011)
Filesystem volume name:   <none>
Last mounted on:          /
Filesystem UUID:          2fca4cbb-22f1-4328-ab13-cacedb360930
Filesystem magic number:  0xEF53
Filesystem revision #:    1 (dynamic)
Filesystem features:      has_journal ext_attr resize_inode dir_index filetype needs_recovery extent flex_bg sparse_super large_file huge_file uninit_bg dir_nlink extra_isize
Filesystem flags:         signed_directory_hash 
Default mount options:    user_xattr acl
Filesystem state:         clean
Errors behavior:          Continue
Filesystem OS type:       Linux
Inode count:              967680
Block count:              3931136
Reserved block count:     0
Free blocks:              2537341
Free inodes:              517736
First block:              0
Block size:               4096
Fragment size:            4096
Reserved GDT blocks:      416
Blocks per group:         32768
Fragments per group:      32768
Inodes per group:         8064
Inode blocks per group:   504
RAID stride:              35637
Flex block group size:    16
Filesystem created:       Thu Mar 15 14:31:04 2012
Last mount time:          Sat Oct 20 20:28:04 2012
Last write time:          Sat Oct 20 20:23:32 2012
Mount count:              1
Maximum mount count:      -1
Last checked:             Sat Oct 20 20:22:57 2012
Check interval:           0 (<none>)
Lifetime writes:          54 GB
Reserved blocks uid:      0 (user root)
Reserved blocks gid:      0 (group root)
First inode:              11
Inode size:           256
Required extra isize:     28
Desired extra isize:      28
Journal inode:            8
First orphan inode:       272350
Default directory hash:   half_md4
Directory Hash Seed:      d582ad79-75a0-4964-9a48-33ddba04df5c
Journal backup:           inode blocks
21
ответ дан 25 May 2018 в 06:36
Если файл содержит какие-либо данные вообще (даже один байт), он будет занимать один блок на диске (обычно это 4k в наши дни). Один блок не может быть разделен между файлами. Это означает, что пространство всего этого блока не будет доступно для других файлов, поэтому оно считается «использованным».

Источник

6
ответ дан 25 May 2018 в 06:36

Другие вопросы по тегам:

Похожие вопросы: