pgsql: Clean up temporary WAL segments after an instance crash

Поиск
Список
Период
Сортировка
От Michael Paquier
Тема pgsql: Clean up temporary WAL segments after an instance crash
Дата
Msg-id E1fdjNh-00059Q-7l@gemulon.postgresql.org
обсуждение исходный текст
Список 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 по дате отправления:

Предыдущее
От: Peter Eisentraut
Дата:
Сообщение: pgsql: Reset shmem_exit_inprogress after shmem_exit()
Следующее
От: Tom Lane
Дата:
Сообщение: Re: pgsql: Allow using the updated tuple while moving it to a different par