OOM killer while pg_restore - Mailing list pgsql-performance

From Marc Rechté
Subject OOM killer while pg_restore
Date
Msg-id 866ba95f-86fb-fa9b-ecee-65281160cff9@rechte.fr
Whole thread Raw
Responses Re: OOM killer while pg_restore  (Ranier Vilela <ranier.vf@gmail.com>)
Re: OOM killer while pg_restore  (Justin Pryzby <pryzby@telsasoft.com>)
Re: OOM killer while pg_restore  (Tom Lane <tgl@sss.pgh.pa.us>)
List pgsql-performance

Hello,

We have a pg_restore which fails due to RAM over-consumption of the corresponding PG backend, which ends-up with OOM killer.

The table has one PK, one index, and 3 FK constraints, active while restoring.
The dump contains over 200M rows for that table and is in custom format, which corresponds to 37 GB of total relation size in the original DB.

While importing, one can see the RSS + swap increasing linearly for the backend (executing the COPY)

On my machine (quite old PC), it failed after 16 hours, while the disk usage was reaching 26 GB and memory usage was 9.1g (RSS+swap)

If we do the same test, suppressing firstly the 5 constraints on the table, the restore takes less than 15 minutes !

This was tested on both PG 14.2 and PG 13.6 (linux 64-bit machines).

It there a memory leak or that is normal that a bacend process may exhaust the RAM to such an extent ?

Thanks

Regards

pgsql-performance by date:

Previous
From: Mladen Gogala
Date:
Subject: Re: Simple task with partitioning which I can't realize
Next
From: Ranier Vilela
Date:
Subject: Re: OOM killer while pg_restore