Por que o host troca VMs quando há 16GB de cache de buffer e swappiness = 0? [duplicado]

5

Eu tenho um desktop rodando o Ubuntu Quantal usando o OpenStack Folsom em um Intel i5 com 32 GB de RAM e 2 GB de swap. Eu estou executando 7 VMs cada tamanho como um EC2 m1.small, então 1,7 GB de RAM cada. Estou usando o KVM.

À medida que me levanto a executar 5 ou 6 ao mesmo tempo, o host começa a trocá-los:

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 )

Eu já tentei definir a permuta para 20, depois para 10 e, finalmente, para 0, nenhuma das quais fez a diferença:

# cat /proc/sys/vm/swappiness 
0

Eu não reiniciei o host desde a alteração de 60 para 0 (preciso reinicializar)? Eu também desliguei completamente o swap com /sbin/swapoff -a; /bin/swapon -a . Imediatamente após a reativação da troca, vejo isto:

$ 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

Eu tenho 15 GB de memória livre que podem ser usados sem ter os processos trocados.

    
por Blair Zajac 12.02.2013 / 08:46

1 resposta

8

I've got 15 GB of free memory that can be used without having the processes swapped out.

Não, você não faz.

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

Você tem 225 MB de memória livre.

KiB Swap: 1998844 total, 1113352 used, 885492 free, 16498252 cached

Veja todo o cache maravilhoso que o sistema fez, em parte obtendo lixo não utilizado de RAM preciosa. Por que você está tentando desperdiçar preciosa memória RAM?

Se você tem 1 GB de dados na RAM que não foram usados em horas, o que faz mais sentido:

  1. Você troca isso para o disco quando não está ocupado e tem mais 1 GB de cache para usar.

  2. Você mantém isso na memória. Você tem 1 GB a menos de cache para usar, e se essa memória for necessária para outra coisa, você terá que trocá-la enquanto estiver ocupado.

Mas se você acha que sabe mais sobre gerenciamento de memória do que as pessoas que escreveram a lógica de gerenciamento de memória do seu sistema operacional, vá em frente e continue tentando descobrir que a mágica "faça tudo mais rápido e melhor".

    
por 12.02.2013 / 10:10