Antes de preguntar, para ser claros: sí, sé sobre caché de disco, y no, no es mi caso :) Lo siento, por este preámbulo :)
Estoy usando CentOS 5. Cada aplicación en el sistema está intercambiando mucho, y el sistema es muy lento. Cuando lo hago free -m
, esto es lo que obtuve:
total used free shared buffers cached
Mem: 3952 3929 22 0 1 18
-/+ buffers/cache: 3909 42
Swap: 16383 46 16337
¡Entonces, en realidad solo tengo 42 Mb para usar! Por lo que entiendo, en -/+ buffers/cache
realidad no cuenta el caché del disco, por lo que solo tengo 42 Mb, ¿verdad? Pensé que podría estar equivocado, así que intenté desactivar el almacenamiento en caché del disco y no tuvo ningún efecto: la imagen seguía siendo la misma.
Entonces, decidí averiguar quién está usando toda mi RAM, y lo usé top
para eso. Pero, aparentemente, informa que ningún proceso está usando mi RAM. El único proceso en mi cima es MySQL, pero está usando 0.1% de RAM y 400Mb de intercambio. La misma imagen cuando intento ejecutar otros servicios o aplicaciones: todos se intercambian, top
muestra que MEM no se usa (0.1% máximo para cualquier proceso).
top - 15:09:00 up 2:09, 2 users, load average: 0.02, 0.16, 0.11
Tasks: 112 total, 1 running, 111 sleeping, 0 stopped, 0 zombie
Cpu(s): 0.0%us, 0.0%sy, 0.0%ni,100.0%id, 0.0%wa, 0.0%hi, 0.0%si, 0.0%st
Mem: 4046868k total, 4001368k used, 45500k free, 748k buffers
Swap: 16777208k total, 68840k used, 16708368k free, 16632k cached
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ SWAP COMMAND
3214 ntp 15 0 23412 5044 3916 S 0.0 0.1 0:00.00 17m ntpd
2319 root 5 -10 12648 4460 3184 S 0.0 0.1 0:00.00 8188 iscsid
2168 root RT 0 22120 3692 2848 S 0.0 0.1 0:00.00 17m multipathd
5113 mysql 18 0 474m 2356 856 S 0.0 0.1 0:00.11 472m mysqld
4106 root 34 19 251m 1944 1360 S 0.0 0.0 0:00.11 249m yum-updatesd
4109 root 15 0 90152 1904 1772 S 0.0 0.0 0:00.18 86m sshd
5175 root 15 0 90156 1896 1772 S 0.0 0.0 0:00.02 86m sshd
Reiniciar no ayuda y, por cierto, es muy lento, lo que normalmente no esperaría en esta máquina (4 núcleos, 4 Gb de RAM, RAID1).
Entonces, con eso, estoy bastante seguro de que este no es un caché de disco, que está usando la RAM, porque normalmente debería haberse reducido y permitir que otros procesos usen RAM, en lugar de ir a intercambiar.
Entonces, finalmente, la pregunta es: ¿si alguien tiene alguna idea de cómo averiguar qué proceso realmente está usando la memoria tanto?
irc.freenode.org
. Creé una sala de chat para una discusión extendida aquí .
free -m
, pero su tamaño puede consultarse en Linux con cat /proc/spl/kstat/zfs/arcstats | grep data_size
.