我正在尝试创建稀疏文件(用于QEMU HDD映像)。
qemu-img
和fallocate
都证明令人困惑。
$ fallocate -l 100M disk.img
$ ls -lsh disk.img
101M -rw-r--r-- 1 i336 users 100M Jul 22 12:03 disk.img
请注意101M
。 strace
显示了一个成功的系统调用:
$ 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