如果 Linux 缓存太大,为什么 QEMU 无法分配内存?

如果 Linux 缓存太大,为什么 QEMU 无法分配内存?

如果我使用我的机器 [Ubuntu 16.04 64 位,内核 4.4] 一段时间,QEMU 需要删除内核缓存,否则它将无法分配 RAM。

为什么会发生这种情况?

这是一个示例运行:

~$ free -m
              total        used        free      shared  buff/cache   available
Mem:          15050        5427        3690          56        5931        4803
Swap:             0           0           0

~$ sudo qemu-system-x86_64 -m 10240 # and other options
qemu-system-x86_64: cannot set up guest memory 'pc.ram': Cannot allocate memory

~$ echo 3 | sudo tee /proc/sys/vm/drop_caches
3

~$ free -m
              total        used        free      shared  buff/cache   available
Mem:          15050        1799        9446          56        3803        9414
Swap:             0           0           0

~$ sudo qemu-system-x86_64 -m 10240 # and other options
qemu-system-x86_64: cannot set up guest memory 'pc.ram': Cannot allocate memory

~$ echo 3 | sudo tee /proc/sys/vm/drop_caches
3

~$ free -m
              total        used        free      shared  buff/cache   available
Mem:          15050        1502       10819          56        2727       10784
Swap:             0           0           0

~$ sudo qemu-system-x86_64 -m 10240 # and other options
# Now QEMU starts

答案1

并非所有缓存数据都可以立即丢弃。例如,缓存的脏页必须先写回到磁盘,然后才能从 RAM 中删除。您没有交换,因此在这些写入完成之前,QEMU 根本没有足够的可用空间。

您确实应该添加合理数量的交换。您不能指望内存管理器在手无寸铁的情况下也能做好工作。

相关内容