Файловая система ext2 или ext3 с максимально доступным пространством

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

Я хочу использовать ext2 или ext3 для общего раздела между Win7 и Ubuntu (с ext2fsd).

Моя проблема в том, что я создал 850-гигабайтный раздел ext2 и GParted говорит:

Size: 853.15 GiB
Used:  13.46 GiB

Это НЕ 5% места, зарезервированного для пользователя root (это будет более 40 гигабайт). И конечно я попробовал tune2fs -m 0 /dev/sda4, Это нормально, что 13 гигабайт теряется только для файловой системы?

Вся помощь приветствуется.

Некоторые детали, если вам это нужно:

# partition table of /dev/sda
unit: sectors

/dev/sda1 : start=     2048, size=   389120, Id=83, bootable
/dev/sda2 : start=   393214, size= 82028546, Id= 5
/dev/sda3 : start= 82429515, size= 81915435, Id= 7
/dev/sda4 : start=164345856, size=1789177856, Id=83
/dev/sda5 : start=   393216, size= 78123008, Id=83
/dev/sda6 : start= 78518272, size=  3903488, Id=82

df говорит:

Filesystem           1K-blocks      Used Available Use% Mounted on
/dev/sda5             38445384   5101796  31390516  14% /
none                   2021640       660   2020980   1% /dev
none                   2029348      1512   2027836   1% /dev/shm
none                   2029348       348   2029000   1% /var/run
none                   2029348         0   2029348   0% /var/lock
/dev/sda1               182331     22620    149983  14% /boot
/dev/sda4            880550492     73744 880476748   1% /media/334cb5f6-2f18-4193-b2c8-99bd42cd6f01

tune2fs -l /dev/sda4 говорит:

tune2fs 1.41.14 (22-Dec-2010)
Filesystem volume name:   
Last mounted on:          
Filesystem UUID:          334cb5f6-2f18-4193-b2c8-99bd42cd6f01
Filesystem magic number:  0xEF53
Filesystem revision #:    1 (dynamic)
Filesystem features:      ext_attr resize_inode dir_index filetype sparse_super large_file
Filesystem flags:         signed_directory_hash 
Default mount options:    (none)
Filesystem state:         clean
Errors behavior:          Continue
Filesystem OS type:       Linux
Inode count:              55918592
Block count:              223647232
Reserved block count:     0
Free blocks:              220119187
Free inodes:              55918581
First block:              0
Block size:               4096
Fragment size:            4096
Reserved GDT blocks:      970
Blocks per group:         32768
Fragments per group:      32768
Inodes per group:         8192
Inode blocks per group:   512
Filesystem created:       Sat May 21 10:35:15 2011
Last mount time:          n/a
Last write time:          Sat May 21 11:21:55 2011
Mount count:              8
Maximum mount count:      20
Last checked:             Sat May 21 10:35:15 2011
Check interval:           15552000 (6 months)
Next check after:         Thu Nov 17 09:35:15 2011
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
Default directory hash:   half_md4
Directory Hash Seed:      7ba9b270-1cc8-4622-b25c-768497678f99

cat /etc/mke2fs.conf говорит:

[defaults]
    base_features = sparse_super,filetype,resize_inode,dir_index,ext_attr
    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
        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
    }
    news = {
        inode_ratio = 4096
    }
    largefile = {
        inode_ratio = 1048576
        blocksize = -1
    }
    largefile4 = {
        inode_ratio = 4194304
        blocksize = -1
    }
    hurd = {
         blocksize = 4096
         inode_size = 128
    }

1 ответ

Решение

После прочтения и последующего прочтения я пришел к выводу, что иноды занимают это огромное количество места.

Вы можете подтвердить это с помощью вывода tune2fs, умножив следующие значения:

Inode count:              55918592
Inode size:               256

... и это действительно даст вам недостающие 13 концертов (14 315 159 552).

В файле make2fs.conf вы можете увидеть следующее по умолчанию: inode_ratio = 16384, Умножение этого числа на количество inode дает полный размер раздела (916 170 211 328), так что это именно то, что кажется. Количество инодов рассчитывается по partition size / inode_ratio,

Поскольку я читаю сокращение размера inode, не рекомендуется, но inode_ratio само даст вам широкое пространство для перемещения. largefile Предустановка создает индекс для каждого 1 МБайт.

Я не зашел так далеко (на этом разделе не будут храниться небольшие файлы операционной системы, но будут загружаться и иногда исходный код), поэтому я получил модерируемое 128000. Он не должен быть степенью 2, иноды не являются зеркалом данных HD 1-1 (например, FAT16), они используются более динамично.

Это (в сочетании с -m 0 конечно) только 2 гигабайта из моего большого раздела. С чем я могу жить.

mkfs.ext3 -i 128000 -m 0 /dev/sda4

Это дало мне 9 миллионов инодов (что ограничивает максимальное количество файлов и каталогов, которые можно хранить на HD). Но, как я сказал ранее, ни одна ОС не будет установлена ​​на нем, и, учитывая, что исходный код ядра Linux содержит около 25 000 файлов, переход от более ранних 55-миллиметровых и 9-миллиметровых inode кажется хорошим компромиссом.

Отказ отответственности:

Выдолжны быть осторожны при настройке inode_ratio, поскольку ваша файловая система будет нести это навсегда. Вы не можете добавить inode к (ext2 или ext3) разделу без переформатирования.

Также невозможно просто сжать раздел и создать новый на свободном пространстве, если у вас закончились inode, потому что сжатие раздела будет пропорционально уменьшать inode, поэтому вы не можете сделать это только с несколькими свободными inode.

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