¿Se está quedando sin memoria o sin espacio en disco?

¿Se está quedando sin memoria o sin espacio en disco?

Estoy ejecutando un proceso de carga de base de datos (osm2pgsql) que falla:

Processing: Node(17404k 148.8k/s) Way(1351k 6.38k/s) Relation(9520 29.94/s)way_done failed: ERROR:  could not extend file "base/140667/152463": No space left on device
HINT:  Check free disk space.
(7)
Arguments were: 187226311, 

Al inicio de la importación, meminforma:

             total       used       free     shared    buffers     cached
Mem:           31G        29G       2.4G         0B       178M        24G
-/+ buffers/cache:       4.5G        26G
Swap:           0B         0B         0B

Poco antes del final:

             total       used       free     shared    buffers     cached
Mem:           31G        31G       227M         0B       178M        26G
-/+ buffers/cache:       4.8G        26G
Swap:           0B         0B         0B

Mientras tanto, dfal principio:

Filesystem     1K-blocks      Used Available Use% Mounted on
/dev/vda1       10309828   7879412   1997036  80% /
udev            16470572        12  16470560   1% /dev
tmpfs            6590080       260   6589820   1% /run
none                5120         0      5120   0% /run/lock
none            16475196         0  16475196   0% /run/shm
none              102400         0    102400   0% /run/user
/dev/vdb       247709760 105978300 129148548  46% /mnt

Y desde aproximadamente 3/4 del proceso. El uso se sitúa al 100%.

Filesystem     1K-blocks      Used Available Use% Mounted on
/dev/vda1       10309828   9854348     22100 100% /
udev            16470572        12  16470560   1% /dev
tmpfs            6590080       260   6589820   1% /run
none                5120         0      5120   0% /run/lock
none            16475196         0  16475196   0% /run/shm
none              102400         0    102400   0% /run/user
/dev/vdb       247709760 105978300 129148548  46% /mnt

No puedo identificar ningún archivo real en el disco que esté llenando /dev/vda1:

du -h -d 3 / 2>/dev/null | grep -v ^0 > /tmp/o2p1.txt
[start import]
du -h -d 3 / 2>/dev/null | grep -v ^0 > /tmp/o2p2.txt

diff /tmp/o2p1.txt /tmp/o2p2.txt

Eso no revela nada.

¿Qué está sucediendo?

Respuesta1

Bueno, fue sencillo. La base de datos de Postgres estaba en /dev/vda1 y se estaba volviendo enorme. No apareció en el ducomando porque no lo estaba ejecutando como root.

Supongo que después de que el disco se llena, Postgres deja de guardar en el disco y lo mantiene todo en la memoria, hasta que la memoria también se agota.

información relacionada