Esecuzione di Ubuntu su un kernel 2.6.31-302 x86-64. Il problema generale è che ho memoria nella categoria 'cache' che continua a salire e non verrà liberata o utilizzata anche quando la nostra applicazione ne ha bisogno.
Quindi, ecco cosa ottengo dal comando 'free'. Niente di tutto ciò sembra fuori dal comune a prima vista.
# free
total used free shared buffers cached
Mem: 7358492 5750320 1608172 0 7848 1443820
-/+ buffers/cache: 4298652 3059840
Swap: 0 0 0
La prima cosa che qualcuno dirà è "Non preoccuparti, Linux gestisce automaticamente quella memoria". Sì, so come dovrebbe funzionare il gestore della memoria; il problema è che non sta facendo la cosa giusta. I 1,4 GB "memorizzati nella cache" qui sembrano essere riservati e inutilizzabili.
La mia conoscenza di Linux mi dice che 3 GB sono "gratuiti"; ma il comportamento del sistema dice il contrario. Quando 1,6 GB di memoria libera reale vengono esauriti durante l'utilizzo di picco, non appena viene richiesta più memoria (e il "libero" nella prima colonna si avvicina a 0) viene invocato il killer OOM, i processi vengono uccisi e iniziano a sorgere problemi anche se il "libero" nella riga - / + buffer / cache ha ancora circa 1,4 GB "libero".
Ho messo a punto i valori di oom_adj sui processi chiave in modo che non metta in ginocchio il sistema, ma anche in questo caso i processi importanti verranno eliminati e non vogliamo mai raggiungere quel punto. Soprattutto quando, in teoria, 1,4 GB è ancora "libero" se sfrattasse solo la cache del disco.
Qualcuno ha idea di cosa sta succedendo qui? Internet è inondato dalle domande stupide sul comando "gratuito" di Linux e "perché non ho memoria libera" e non riesco a trovare nulla su questo problema a causa di ciò.
La prima cosa che mi viene in mente è che lo swap è disattivato. Abbiamo un amministratore di sistema che è irremovibile al riguardo; Sono aperto alle spiegazioni se sono state salvate. Questo potrebbe causare problemi?
Ecco gratis dopo l'esecuzione echo 3 > /proc/sys/vm/drop_caches
:
# free
total used free shared buffers cached
Mem: 7358492 5731688 1626804 0 524 1406000
-/+ buffers/cache: 4325164 3033328
Swap: 0 0 0
Come puoi vedere, una piccola quantità di cache viene effettivamente liberata, ma circa 1,4 GB sembra essere "bloccato". L'altro problema è che questo valore sembra aumentare nel tempo. Su un altro server 2,0 GB è bloccato.
Mi piacerebbe davvero questo ricordo ... qualsiasi aiuto sarebbe molto apprezzato.
Ecco cat /proc/meminfo
se vale qualcosa:
# cat /proc/meminfo
MemTotal: 7358492 kB
MemFree: 1472180 kB
Buffers: 5328 kB
Cached: 1435456 kB
SwapCached: 0 kB
Active: 5524644 kB
Inactive: 41380 kB
Active(anon): 5492108 kB
Inactive(anon): 0 kB
Active(file): 32536 kB
Inactive(file): 41380 kB
Unevictable: 0 kB
Mlocked: 0 kB
SwapTotal: 0 kB
SwapFree: 0 kB
Dirty: 320 kB
Writeback: 0 kB
AnonPages: 4125252 kB
Mapped: 42536 kB
Slab: 29432 kB
SReclaimable: 13872 kB
SUnreclaim: 15560 kB
PageTables: 0 kB
NFS_Unstable: 0 kB
Bounce: 0 kB
WritebackTmp: 0 kB
CommitLimit: 3679244 kB
Committed_AS: 7223012 kB
VmallocTotal: 34359738367 kB
VmallocUsed: 7696 kB
VmallocChunk: 34359729675 kB
DirectMap4k: 7340032 kB
DirectMap2M: 0 kB