Como a memória física usada pode exceder a soma da memória 'residente' relatada pelos processos?

Como a memória física usada pode exceder a soma da memória 'residente' relatada pelos processos?

Dada a saída topmostrada abaixo (que mostratodosprocessos atualmente ativos): como é possível que este servidor virtual relate ~500M de memória física como usada (usada - armazenada em cache, verificada por free), enquanto a soma de 'RES' é muito menor que isso? A soma de sempre não deveria RESexceder a memória física usada? Para que a memória poderia ser usada e para quê?

top - 08:43:23 up 75 days,  5:00,  1 user,  load average: 0.08, 0.08, 0.04
Tasks:  29 total,   1 running,  28 sleeping,   0 stopped,   0 zombie
Cpu(s):  0.2%us,  0.1%sy,  0.0%ni, 99.7%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st
Mem:   2400000k total,   713792k used,  1686208k free,        0k buffers
Swap:        0k total,        0k used,        0k free,   200764k cached

  PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND                                                                                                                           
    1 root      20   0 19232  544  384 S  0.0  0.0   0:00.08 init                                                                                                                              
    2 root      20   0     0    0    0 S  0.0  0.0   0:00.00 kthreadd/201208                                                                                                                   
    3 root      20   0     0    0    0 S  0.0  0.0   0:00.00 khelper/2012080                                                                                                                   
  323 pdns-rec  20   0  169m 2980 1152 S  0.0  0.1   1:58.98 pdns_recursor                                                                                                                     
  560 root      20   0  6160  200  196 S  0.0  0.0   0:00.00 portreserve                                                                                                                       
  578 dbus      20   0 21536  324  284 S  0.0  0.0   0:00.00 dbus-daemon                                                                                                                       
  598 nobody    20   0 17040 2108  880 S  0.0  0.1   4:48.33 openvpn                                                                                                                           
  607 nobody    20   0 16124 1112  724 S  0.0  0.0   0:41.54 openvpn                                                                                                                           
 1347 root      20   0 78732  592  508 S  0.0  0.0   0:12.35 master                                                                                                                            
 1355 postfix   20   0 78984  612  516 S  0.0  0.0   0:02.63 qmgr                                                                                                                              
 1515 root      20   0  9232  564  396 S  0.0  0.0   0:39.69 gam_server                                                                                                                        
11077 root      16  -4 10648  272  268 S  0.0  0.0   0:00.00 udevd                                                                                                                             
12912 root      20   0  168m  57m 3040 S  0.0  2.4   0:56.31 puppetd                                                                                                                           
13187 root      20   0 11308 1224 1220 S  0.0  0.1   0:00.00 mysqld_safe                                                                                                                       
13295 mysql     20   0 1348m  44m 4232 S  0.0  1.9 246:49.61 mysqld                                                                                                                            
13391 root      20   0 66608  516  404 S  0.0  0.0   0:00.00 sshd                                                                                                                              
13411 root      20   0 20468  740  644 S  0.0  0.0   0:00.71 crond                                                                                                                             
13452 root      20   0  243m 1428  820 S  0.0  0.1   0:00.36 rsyslogd                                                                                                                          
16087 app       20   0 14896 1096  880 R  0.0  0.0   0:00.00 top                                                                                                                               
18993 newrelic  20   0 25764  124   84 S  0.0  0.0   0:00.00 nrsysmond                                                                                                                         
18994 newrelic  20   0  103m 1540 1036 S  0.0  0.1   0:46.22 nrsysmond                                                                                                                         
23268 postfix   20   0 81356 3384 2508 S  0.0  0.1   0:00.00 pickup                                                                                                                            
29550 root      20   0  387m 3516 1088 S  0.0  0.1   2:25.48 fail2ban-server                                                                                                                   
31434 root      20   0 96264 2408 2376 S  0.0  0.1   0:00.00 sshd                                                                                                                              
31438 user      20   0 96264  816  640 S  0.0  0.0   0:00.25 sshd                                                                                                                              
31439 user      20   0  105m 1264 1260 S  0.0  0.1   0:00.00 bash                                                                                                                              
31456 root      20   0  165m 1768 1764 S  0.0  0.1   0:00.00 sudo                                                                                                                              
31457 root      20   0  138m 1020 1016 S  0.0  0.0   0:00.00 su                                                                                                                                
31458 app       20   0 13440 3332 1492 S  0.0  0.1   0:00.07 bash   

Nota: o que estou perguntando é exatamente o inverso do que as pessoas costumam perguntar.

Requeridos cat /proc/memoinfo:

MemTotal:        2400000 kB
MemFree:         1682660 kB
Cached:           202948 kB
Active:           132988 kB
Inactive:         180704 kB
Active(anon):      19668 kB
Inactive(anon):    91076 kB
Active(file):     113320 kB
Inactive(file):    89628 kB
Unevictable:           0 kB
Mlocked:               0 kB
SwapTotal:             0 kB
SwapFree:              0 kB
Dirty:                 4 kB
Writeback:             0 kB
AnonPages:        110744 kB
Shmem:              2568 kB
Slab:            2268056 kB
SReclaimable:    2260740 kB
SUnreclaim:         7316 kB

Acredito que a tecnologia de virtualização seja Virtuozzo.

Responder1

Especificamente relacionado às VMs, o uso de RAM parece diferente quando você está "lá fora, olhando para dentro" contra "dentro, olhando ao redor"

Por que uma VM relata aproximadamente 500 MB usados, mas topmostra muito menos RAM em uso?

Se a VM estiver relatando aproximadamente 500 MB usados ​​(no gerenciador de VM, presumo), mas o total RESfor muito menor, isso é esperado.

Uma VM (seja VMware, contêiner Virtuozzo, Hyper-V ou Solaris Zone) consome mais RAM do que apenas seus processos usam. A "sobrecarga" necessária para realmente executar a VM é agregada a essa métrica (mapeamentos de dispositivos virtuais, caches de dispositivos virtuais (como rede e disco), espaço do kernel, etc.)

Para completar, fornecerei uma breve explicação do problema "oposto" que a maioria das pessoas pergunta (foi assim que encontrei esta pergunta)

Tamanho do "Conjunto Residente" do topo ( RES) "maior" que a Memória Física

O tamanho do conjunto residente é calculado pelo kernel como a soma de páginas "anônimas" ( ) e páginas MM_ANONPAGES"apoiadas em arquivo" ( ). MM_FILEPAGESComo uma única página pode ser contada várias vezes (atribuída a vários processos), isso explica por que RESin topé calculado a partir de cada processo em execução, parece que está consumindo mais memória do que possível.

informação relacionada