当缓冲区缓存为 16GB 且 swappiness = 0 时,为什么主机会换出虚拟机?

当缓冲区缓存为 16GB 且 swappiness = 0 时,为什么主机会换出虚拟机?

我有一台运行 Ubuntu Quantal 的桌面,它使用 OpenStack Folsom 在 Intel i5 上,配有 32 GB RAM 和 2 GB 交换空间。我运行了 7 个虚拟机,每个虚拟机的大小都像 EC2 m1.small,所以每个虚拟机有 1.7 GB RAM。我使用的是 KVM。

当我同时运行 5 或 6 个时,主机开始将它们换出:

top - 23:45:42 up 3 days,  1:51, 10 users,  load average: 0.37, 0.75, 1.15
Tasks: 418 total,   2 running, 413 sleeping,   3 stopped,   0 zombie
%Cpu(s):  8.8 us,  2.1 sy,  0.0 ni, 88.8 id,  0.0 wa,  0.0 hi,  0.3 si,  0.0 st
KiB Mem:  32864580 total, 32586956 used,   277624 free,   574236 buffers
KiB Swap:  1998844 total,  1113352 used,   885492 free, 16498252 cached

  PID USER      PR  NI  VIRT  RES  SHR S  %CPU %MEM    TIME+  COMMAND           
24652 libvirt-  20   0 4169m 1.7g 7756 S   3.6  5.4   4:49.37 kvm               
25233 libvirt-  20   0 4450m 1.6g 7756 S   1.2  5.2   4:35.12 kvm               
25589 libvirt-  20   0 4163m 1.6g 7756 S   2.4  5.1   4:40.31 kvm               
 6562 root      39  19 2935m 658m 7460 S   0.0  2.1 100:05.62 java              
28393 libvirt-  20   0 4149m 624m 7756 S   0.0  1.9   2:25.01 kvm               
28106 libvirt-  20   0 4170m 617m 7756 S   0.0  1.9   2:18.17 kvm               
26519 libvirt-  20   0 4167m 590m 7756 S   0.0  1.8   2:22.16 kvm               
29399 libvirt-  20   0 4159m 589m 7756 S   0.0  1.8   2:19.94 kvm               


$ free -m
             total       used       free     shared    buffers     cached
Mem:         32094      31868        225          0        559      16175
-/+ buffers/cache:      15134      16959
Swap:         1951       1087        864


# /tmp/swap-used.sh |grep kvm
PID=944 - Swap used: 0 - (kvm-irqfd-clean )
PID=24652 - Swap used: 102468 - (kvm )
PID=25233 - Swap used: 108644 - (kvm )
PID=25589 - Swap used: 155768 - (kvm )
PID=26519 - Swap used: 192216 - (kvm )
PID=28106 - Swap used: 150796 - (kvm )
PID=28393 - Swap used: 208488 - (kvm )
PID=29399 - Swap used: 187388 - (kvm )

我已经尝试将 swapiness 设置为 20,然后设置为 10,最后设置为 0,但都没有任何区别:

# cat /proc/sys/vm/swappiness 
0

自从将主机从 60 改为 0 后,我还没有重启过主机(我需要重启吗)?我还用 完全关闭了交换/sbin/swapoff -a; /bin/swapon -a。重新启用交换后,我立即看到以下内容:

$ vmstat 5
procs -----------memory---------- ---swap-- -----io---- -system-- ----cpu----
 r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa
 2  0  11384 247572 652736 16539748   11   10   291   228   13   12  7  3 87  3
 0  0  12968 234360 652756 16554432    0  317  8576  1240 3508 5470 17  2 75  5
 1  0  17068 243512 652768 16559508    0  820  9448  1216 3687 4845 20  2 77  2
 1  0  20040 233300 652772 16576152    0  594 12262   677 4436 5063 29  2 68  1
 1  0  22764 219156 652792 16594448    6  546 11962   727 3870 4559 28  1 68  2
 3  0  40832 229384 652776 16602440    0 3614 58404  4176 2051 6231 21  2 66 10
 1  0  52420 232236 652784 16613320    0 2318 42174  2512 1819 4026 15  2 77  6

我有 15 GB 的可用内存,无需交换进程即可使用。

答案1

我有 15 GB 的可用内存,无需交换进程即可使用。

不,你不需要。

           total       used       free     shared    buffers     cached
Mem:       32094      31868        225          0        559      16175

您有 225MB 的可用内存。

KiB 交换:总计 1998844,已使用 1113352,可用 885492,缓存 16498252

看看系统创建的所有出色缓存,部分原因是从宝贵的 RAM 中清除了未使用的垃圾。你为什么要让它浪费宝贵的 RAM?

如果您的 RAM 中有 1GB 的数据已经几个小时没有使用了,那么这更有意义:

  1. 当您不忙时,您可以将其交换到磁盘并有 1GB 以上的缓存可供使用。

  2. 你将其保存在内存中。这样你就少用了 1GB 的缓存,如果这部分内存用于其他用途,你就必须在繁忙时将其换出。

但是如果您认为您比编写操作系统内存管理逻辑的人更了解内存管理,那么请继续尝试寻找那个神奇的“更快更好地完成所有事情”的开关。

相关内容