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

From Christophe Pettus
Subject Re: Replication slot WAL reservation
Date
Msg-id 270FB587-2E83-4EB0-9FD6-07541F2A6A17@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

> On Mar 25, 2025, at 13:58, Phillip Diffley <phillip6402@gmail.com> wrote:
>
> Oh I see! I was conflating the data I see coming out of a replication slot with the internal organization of the WAL.
Ithink the more specific question I am trying to answer is, as a consumer of a replication slot, how do I reason about
whatreplication records will be made unavailable when I confirm an LSN? Here I am worried about situations where the
replicationconnection is interrupted or the program processing the records crashes, and we need to replay records that
mayhave been previously sent but were not fully processed. 

It's up to the consuming client to keep track of where it is in the WAL (using an LSN).  When the client connects, it
specifieswhat LSN to start streaming at.  If that LSN is no longer available, the publisher / primary returns an error. 

The client shouldn't confirm the flush of an LSN unless it is crash-proof to that point, since any WAL before that
shouldbe assumed to be unavailable. 

> For example, are the records sent by a replication slot always sent in the same order such that if I advance the
confirmed_flush_lsnof a slot to the LSN of record "A", I will know that any records that had been streamed after record
"A"will be replayable? 

You know that any WAL generated after `confirmed_flush_lsn` is available for replay.  That's the oldest LSN that the
clientcan specify on connection (although it can specify a later one, if it exists).  You shouldn't need to manually
advancethe replication slot.  Instead, the client specifies where it wants to start when it connects.  The client is
alsoexpected to send back regular messages letting the publisher / primary know that it has successfully consumed up to
aparticular point in the WAL, so the publisher / primary knows it can release that WAL information. 


pgsql-general by date:

Previous
From: Phillip Diffley
Date:
Subject: Re: Replication slot WAL reservation
Next
From: Karsten Hilbert
Date:
Subject: Q on SELECT column list pushdown from view to table