为什么每个目录的大小为4096字节(4 K)?


33

正如主题所说;我想知道为什么每个目录都包含等于4K的目录,即使它们包含大于4K的文件也是如此。

请看以下内容:

$ ls -lh
total 2.0M
drwxr-xr-x 4 ankit ankit 4.0K Sep 11 07:28 Desktop

$ ls -lrh Desktop/
-rw-rw-r-- 1 ankit ankit 9.1M Aug 4 11:15 sophosthreatsaurusaz.pdf
-rw------- 1 ankit ankit 107K Dec 27 2010 KP 3 0.pdf
drwxrwsr-x 9 ankit ankit 4.0K Sep 10 19:26 eclipse

PS:我知道du -sh命令行实用程序。

编辑:我假设目录作为文件的容器。


它是目录的元数据
Tachyons 2012年

Answers:


34
  • 无需太过专业,就可以将目录条目看作是指向目录“包含”的文件列表的“链接” 。
  • 然后,与所有内容一样,ls向您显示该链接的大小,而不是目录内容所占用的总空间。
  • 文件或目录条目/链接必须占用的最小大小为一个块,在大多数ext3 / 4文件系统上通常为4096字节/ 4K。

7
您说“文件或目录条目/链接必须占用的最小大小是一个块”,但是我确信我看到的文件大小小于4K。
Lakshay Garg

1
@LakshayGarg虽然文件可以小于4K,但是它将导致所谓的“内部碎片”,其中仅几个字节的块已用于存储小文件。
phyloflash

@phyloflash某些文件系统(例如NTFS)将小文件存储在文件条目本身中(对于NTFS,它在MFT条目中)。这样,它们的内容占据了零分配块,并且减少了内部碎片。
Ruslan

26

为了理解这一点,您最好对以下内容(文件系统)有一些基本了解:

  • 索引节点(包含文件属性,文件元数据,指针结构)
  • 文件(可以认为是具有两列的表,文件名及其索引节点,索引节点指向块设备上的原始数据块)
  • 目录(只是一个特殊文件,是其他文件名的容器。它包含文件名数组和每个文件名的索引节点编号。还描述了父级和子级之间的关系。)
  • 符号链接VS硬链接
  • 牙科(目录条目)
  • ...

在典型的ext4文件系统(大多数人使用的文件系统)上,默认inode大小为256字节,块大小为4096字节。

目录只是一个特殊文件,其中包含文件名和索引节点编号的数组。创建目录时,文件系统使用“文件名”(实际上是目录名)为目录分配了1个索引节点。索引节点指向单个数据块(最小开销),该数据块为4096字节。这就是使用时看到4096 / 4.0K的原因ls

您可以使用tune2fs&获取详细信息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

7

如果文件完全包含任何数据(甚至单个字节),它将占用磁盘上的一个块(目前通常为4k)。文件之间不能共享一个块。这意味着整个块的空间将无法用于其他文件,因此被视为“已用”。

资源

By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.