Alto uso de memória, mas nenhum processo está usando

11

Eu corro free -m em uma VM debian em execução no Hyper-V:

             total       used       free     shared    buffers     cached
Mem:         10017       9475        541        147         34        909
-/+ buffers/cache:       8531       1485
Swap:         1905          0       1905

Portanto, dos meus 10 GB de memória, 8.5 GB estão em uso e apenas 1500 MB são gratuitos (excluindo o cache).

Mas eu me esforço para encontrar o que está usando a memória. A saída de ps aux | awk '{sum+=$6} END {print sum / 1024}' , que deve somar a utilização de RSS é:

1005.2

Em outras palavras, meus processos usam apenas 1 GB de memória, mas o sistema como um todo (excluindo o cache) usa 8,5 GB.

O que poderia estar usando os outros 7,5 GB?

ps: Eu tenho outro servidor com uma configuração similar que mostra mem usado de 1200 (mem livre = 8.8GB) e a soma do uso de RSS em ps é 900, o que é mais próximo do que eu esperaria ...

EDITAR

cat /proc/meminfo na máquina 1 (pouca memória):

MemTotal:       10257656 kB
MemFree:          395840 kB
MemAvailable:    1428508 kB
Buffers:          162640 kB
Cached:          1173040 kB
SwapCached:          176 kB
Active:          1810200 kB
Inactive:         476668 kB
Active(anon):     942816 kB
Inactive(anon):   176184 kB
Active(file):     867384 kB
Inactive(file):   300484 kB
Unevictable:           0 kB
Mlocked:               0 kB
SwapTotal:       1951740 kB
SwapFree:        1951528 kB
Dirty:                16 kB
Writeback:             0 kB
AnonPages:        951016 kB
Mapped:           224388 kB
Shmem:            167820 kB
Slab:              86464 kB
SReclaimable:      67488 kB
SUnreclaim:        18976 kB
KernelStack:        6736 kB
PageTables:        13728 kB
NFS_Unstable:          0 kB
Bounce:                0 kB
WritebackTmp:          0 kB
CommitLimit:     7080568 kB
Committed_AS:    1893156 kB
VmallocTotal:   34359738367 kB
VmallocUsed:       62284 kB
VmallocChunk:   34359672552 kB
HardwareCorrupted:     0 kB
AnonHugePages:         0 kB
HugePages_Total:       0
HugePages_Free:        0
HugePages_Rsvd:        0
HugePages_Surp:        0
Hugepagesize:       2048 kB
DirectMap4k:       67520 kB
DirectMap2M:    10418176 kB

cat /proc/meminfo na máquina 2 (uso normal da memória):

MemTotal:       12326128 kB
MemFree:         8895188 kB
MemAvailable:   10947592 kB
Buffers:          191548 kB
Cached:          2188088 kB
SwapCached:            0 kB
Active:          2890128 kB
Inactive:         350360 kB
Active(anon):    1018116 kB
Inactive(anon):    33320 kB
Active(file):    1872012 kB
Inactive(file):   317040 kB
Unevictable:           0 kB
Mlocked:               0 kB
SwapTotal:       3442684 kB
SwapFree:        3442684 kB
Dirty:                44 kB
Writeback:             0 kB
AnonPages:        860880 kB
Mapped:           204680 kB
Shmem:            190588 kB
Slab:              86812 kB
SReclaimable:      64556 kB
SUnreclaim:        22256 kB
KernelStack:       10576 kB
PageTables:        11924 kB
NFS_Unstable:          0 kB
Bounce:                0 kB
WritebackTmp:          0 kB
CommitLimit:     9605748 kB
Committed_AS:    1753476 kB
VmallocTotal:   34359738367 kB
VmallocUsed:       62708 kB
VmallocChunk:   34359671804 kB
HardwareCorrupted:     0 kB
AnonHugePages:         0 kB
HugePages_Total:       0
HugePages_Free:        0
HugePages_Rsvd:        0
HugePages_Surp:        0
Hugepagesize:       2048 kB
DirectMap4k:       63424 kB
DirectMap2M:    12519424 kB
    
por assylias 03.02.2016 / 19:49

2 respostas

8

Eu entendo que você está usando o Hyper-V, mas os conceitos são semelhantes. Talvez isso te coloque no caminho certo.

Seu problema provavelmente se deve ao ballooning de memória virtual, uma técnica que o hypervisor usa para otimizar a memória. Consulte este link para obter uma descrição

Eu observei exatamente seus mesmos sintomas com minhas VMs no vSphere. Uma máquina 4G sem nada rodando reportaria 30M usado pelo cache, mas por 3G "usado" na linha "- / + buffers".

Aqui está um exemplo de saída do comando de estatísticas do VMWare. Isso mostra o quão perto de 3G está sendo adicionado ao meu valor "usado":

vmware-toolbox-cmd stat balloon
3264 MB

No meu caso, obviamente, meu driver de balão estava usando ~ 3G

Não sei ao certo qual é o comando semelhante no Hyper-V para obter suas estatísticas de balão, mas tenho certeza de que você obterá resultados semelhantes

    
por 10.02.2016 / 19:07
1

link

Resposta curta: o kernel usa buffers / memória cache para várias tarefas, como arquivos em cache. Esta memória está disponível para aplicações se for necessário, então você está correto em dizer que você tem 944 MB usado.

    
por 03.02.2016 / 20:04