Re: Replication slot WAL reservation - Mailing list pgsql-general

From Christophe Pettus
Subject Re: Replication slot WAL reservation
Date
Msg-id E08677AC-AE92-40A1-9C46-9C8BA4529FE7@thebuild.com
Whole thread Raw
In response to Replication slot WAL reservation  (Phillip Diffley <phillip6402@gmail.com>)
Responses Re: Replication slot WAL reservation
List pgsql-general
Missed this question!

> On Mar 25, 2025, at 09:56, Phillip Diffley <phillip6402@gmail.com> wrote:
> But when processing data from a replication slot, we confirm rows that have been processed and can be deleted from
theWAL based on the LSN (eg. with pg_replication_slot_advance). How does postgres identify what parts of the WAL can be
freed?

Basically, if no part of the system "needs" a particular LSN position, the segments that include that LSN position and
earliercan be free. 

The various things that can "need" a particular LSN point are:

1. Replication slots, if the other side has not confirmed that it has received it (under whatever synchronous commit
rulesthat slot is operating under). 
2. The wal_keep_size setting.
3. The max_wal_size setting.
4. The archive_command, if a WAL segment hasn't been successfully archived yet.

One thing to remember is that the WAL does *not* contain contiguous blocks of operations for a single transaction.  The
operationsare written to the WAL by every session as they do operations, so the WAL is a jumble of different
transactions. One of the jobs of the logical replication framework is to sort that out so it can present only the
operationsthat belong to committed transactions to the output plugin.  (This is why there's an internal structure
calledthe "reorder buffer": it reorders WAL operations into transaction blocks.) 


pgsql-general by date:

Previous
From: Tom Lane
Date:
Subject: Re: How to pass a list of locations (longitude, latitude) to a PostgreSQL/PostGIS stored function?
Next
From: Christoph Berg
Date:
Subject: Re: How to pass a list of locations (longitude, latitude) to a PostgreSQL/PostGIS stored function?