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

正如主题所说; 我想知道为什么每个目录的大小都等于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命令行实用程序。

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

  • 在没有过于技术化的情况下,将目录条目视为目录“包含”文件列表的“链接”。
  • 然后,与所有内容一样, ls显示该链接的大小,而不是目录内容占用的总空间。
  • 文件或目录条目/链接必须占用的最小大小是一个块,在大多数ext3 / 4文件系统上通常为4096字节/ 4K。

要理解这一点,您最好具备以下(文件系统)的一些基本知识:

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

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

目录只是一个特殊文件,其中包含文件名和inode编号的数组。 创建目录时,文件系统将1 inode分配给具有“filename”(实际上为dir名称)的目录。 inode指向单个数据块(最小开销),即4096字节。 这就是为什么你在使用ls时看到4096 / 4.0K的原因。

您可以使用tune2fsdumpe2fs获取详细信息。

 root@ubuntu:~# tune2fs -l /dev/ubuntu/root tune2fs 1.42 (29-Nov-2011) Filesystem volume name:  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 () 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 

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

资源