pgsql: Clean up temporary WAL segments after an instance crash - Mailing list pgsql-committers

From Michael Paquier
Subject pgsql: Clean up temporary WAL segments after an instance crash
Date
Msg-id E1fdjNh-00059Q-7l@gemulon.postgresql.org
Whole thread Raw
List pgsql-committers
Clean up temporary WAL segments after an instance crash

Temporary WAL segments are created in pg_wal and named as xlogtemp.pid
before being renamed to the real deal when creating a new segment.  If
an instance crashes after the temporary segment is created and before
the rename is done, then the server would finish with unremovable data.

After an instance crash, scan pg_wal and remove any such segments.  With
repetitive unlucky crashes this would contribute to disk bloat and
presents risks of ENOSPC especially with max_wal_size close to the
maximum allowed.

Author: Michael Paquier
Reviewed-by: Yugo Nagata, Heikki Linnakangas
Discussion: https://postgr.es/m/20180514054955.GF1528@paquier.xyz

Branch
------
master

Details
-------
https://git.postgresql.org/pg/commitdiff/5fc1008e8a8b9e96ac75b4db5dd9ad2b99a9c8b2

Modified Files
--------------
src/backend/access/transam/xlog.c | 52 +++++++++++++++++++++++++++++++++------
1 file changed, 45 insertions(+), 7 deletions(-)


pgsql-committers by date:

Previous
From: Peter Eisentraut
Date:
Subject: pgsql: Reset shmem_exit_inprogress after shmem_exit()
Next
From: Tom Lane
Date:
Subject: Re: pgsql: Allow using the updated tuple while moving it to a different par