正如主题所说;我想知道为什么每个目录的大小都等于 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
命令行实用程序。
编辑:我假设目录是文件的容器。
答案1
- 不用太过技术性,我们可以将目录条目简单地视为指向一个列表目录“包含”的文件。
- 然后,像所有东西一样,
ls
显示尺寸该链接,而不是目录内容占用的总空间。 - 文件或目录条目/链接必须占用的最小大小是一个块,在大多数 ext3/4 文件系统上通常为 4096 字节/4K。
答案2
为了理解这一点,您最好具备以下一些基本知识(文件系统):
- 索引节点(包含文件属性,文件元数据,指针结构)
- 文件(可以认为是一个有2列的表,文件名及其inode,inode指向块设备上的原始数据块)
- 目录(只是一个特殊的文件,其他文件名的容器。它包含一个文件名数组和每个文件名的 inode 编号。它还描述了父级和子级之间的关系。)
- 符号链接 VS 硬链接
- dentry(目录项)
- ...
在典型的ext4
文件系统(大多数人使用的)中,默认inode
大小为 256 字节,块大小为 4096 字节。
目录只是一个特殊的文件,其中包含文件名和 inode 编号的数组。创建目录时,文件系统会为目录分配 1 个 inode,并使用“文件名”(实际上是目录名)。inode 指向单个数据块(最小开销),大小为 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
答案3
如果文件包含任何数据(即使只有一个字节),它将占用磁盘上的一个块(目前通常为 4k)。一个块不能在文件之间共享。这意味着整个块的空间将不可用于其他文件,因此它被视为“已使用”。