稀疏文件一次占用所有fallocate()d空间

时间:2017-07-22 02:18:50

标签: sparse-file

我正在尝试创建稀疏文件(用于QEMU HDD映像)。

qemu-imgfallocate都证明令人困惑。

$ fallocate -l 100M disk.img

$ ls -lsh disk.img
101M -rw-r--r-- 1 i336 users 100M Jul 22 12:03 disk.img

请注意101Mstrace显示了一个成功的系统调用:

$ strace fallocate -l 100M disk.img
open("disk.img", O_RDWR|O_CREAT|O_LARGEFILE, 0666) = 3
fallocate(3, 0, 0, 104857600)           = 0

$ ls -lsh disk.img
101M -rw-r--r-- 1 i336 users 100M Jul 22 12:03 disk.img

我不确定stat是否是正确的工具,但以防万一..

$ stat disk.img
  File: 'disk.img'
  Size: 104857600       Blocks: 204808     IO Block: 4096   regular file
Device: 802h/2050d      Inode: 549166      Links: 1
Access: (0644/-rw-r--r--)  Uid: ( 1337/    i336)   Gid: (  100/   users)

可能(非常奇怪)的线索:104857600/204808 = 511.9800。 (文件大小/块数)

qemu-img具有类似的输出。 (我在手册中找到了preallocation选项。)

$ qemu-img create -f raw -o preallocation=falloc disk.img 100M
Formatting 'disk.img', fmt=raw size=104857600 preallocation=falloc

$ ls -lsh disk.img
101M -rw-r--r-- 1 i336 users 100M Jul 22 12:06 disk.img

这是令人讨厌的一点:图像似乎是在磁盘上使用真实空间。

$ df -h /; fallocate -l 1G disk.img; df -h /
Filesystem      Size  Used Avail Use% Mounted on
/dev/root        48G   43G  3.5G  93% /
Filesystem      Size  Used Avail Use% Mounted on
/dev/root        48G   44G  2.5G  95% /

然而,就像稀疏文件一样,它需要时间来创建!

$ time fallocate -l 3.3G disk.img
0.00user 0.57system 0:00.91elapsed 63%CPU (0avgtext+0avgdata 5424maxresident)k
200inputs+0outputs (0major+68minor)pagefaults 0swaps
在5400RPM硬盘上,

0.91秒。我无法创建稀疏文件。

然而,无论我使用什么工具,它似乎都在使用101MB的空间。

我可能做错了什么或配置错误?

$ cat /etc/fstab
/dev/sda2 / ext4 rw,user_xattr 0 0

0 个答案:

没有答案