Re: Minimal logical decoding on standbys - Mailing list pgsql-hackers

From Amit Kapila
Subject Re: Minimal logical decoding on standbys
Date
Msg-id CAA4eK1L_Zc+7cjm0OhktiPT5xn3=yXn6oenLuEyvJY_CM6T6Mw@mail.gmail.com
Whole thread Raw
In response to Re: Minimal logical decoding on standbys  ("Drouvot, Bertrand" <bertranddrouvot.pg@gmail.com>)
Responses Re: Minimal logical decoding on standbys  (Amit Kapila <amit.kapila16@gmail.com>)
Re: Minimal logical decoding on standbys  ("Drouvot, Bertrand" <bertranddrouvot.pg@gmail.com>)
List pgsql-hackers
On Wed, Apr 5, 2023 at 2:41 PM Drouvot, Bertrand
<bertranddrouvot.pg@gmail.com> wrote:
>
> On 4/5/23 8:59 AM, Amit Kapila wrote:
> > On Mon, Apr 3, 2023 at 12:05 PM Amit Kapila <amit.kapila16@gmail.com> wrote:
>
> > On further thinking, as such this shouldn't be a problem because all
> > the WAL records before PARAMETER_CHANGE record will have sufficient
> > information so that they can get decoded. However, with the current
> > approach, the subscriber may not even receive the valid records before
> > PARAMETER_CHANGE record. This is because startup process will
> > terminate the walsenders while invaliding the slots and after restart
> > the walsenders will exit because the corresponding slot will be an
> > invalid slot. So, it is quite possible that walsender was lagging and
> > wouldn't have sent records before the PARAMETER_CHANGE record making
> > subscriber never receive those records that it should have received.
>
> Agree that would behave that way.
>
> > I don't know whether this is what one would expect.
>
> If one change wal_level to < logical on the primary, he should at least
> know that:
>
> "
> Existing
> +     logical slots on standby also get invalidated if wal_level on primary is reduced to
> +     less than 'logical'.
> "
>
> If the doc has been read (as the quote above is coming from 0006).
>
> I think that what is missing is the "when" the slots are invalidated.
>
> Maybe we could change the doc with something among those lines instead?
>
> "
> Existing logical slots on standby also get invalidated if wal_level on primary is reduced to
> less than 'logical'. This is done as soon as the standby detects such a change in the WAL stream.
>
> It means, that for walsenders that are lagging (if any), some WAL records up to the parameter change on the
> primary won't be decoded".
>
> I don't know whether this is what one would expect but that should be less of a surprise if documented.
>
> What do you think?
>

Yeah, I think it is better to document to avoid any surprises if
nobody else sees any problem with it. BTW, another thought that
crosses my mind is that let's not invalidate the slots when the
standby startup process processes parameter_change record and rather
do it when walsender decodes the parameter_change record, if we think
that is safe. I have shared this as this crosses my mind while
thinking about this part of the patch and wanted to validate my
thoughts, we don't need to change even if the idea is valid.

minor nitpick:
+
+ /* Intentional fall through to session cancel */
+ /* FALLTHROUGH */

Do we need to repeat fall through twice in different ways?

--
With Regards,
Amit Kapila.



pgsql-hackers by date:

Previous
From: Peter Eisentraut
Date:
Subject: Re: meson documentation build open issues
Next
From: Alvaro Herrera
Date:
Subject: Re: logical decoding and replication of sequences, take 2