Re: Minimal logical decoding on standbys

From: "Drouvot, Bertrand" <bertranddrouvot(dot)pg(at)gmail(dot)com>
To: Amit Kapila <amit(dot)kapila16(at)gmail(dot)com>
Cc: Alvaro Herrera <alvherre(at)alvh(dot)no-ip(dot)org>, Jeff Davis <pgsql(at)j-davis(dot)com>, Andres Freund <andres(at)anarazel(dot)de>, Robert Haas <robertmhaas(at)gmail(dot)com>, Thomas Munro <thomas(dot)munro(at)gmail(dot)com>, Ibrar Ahmed <ibrar(dot)ahmad(at)gmail(dot)com>, Amit Khandekar <amitdkhan(dot)pg(at)gmail(dot)com>, fabriziomello(at)gmail(dot)com, tushar <tushar(dot)ahuja(at)enterprisedb(dot)com>, Rahila Syed <rahila(dot)syed(at)2ndquadrant(dot)com>, pgsql-hackers <pgsql-hackers(at)postgresql(dot)org>
Subject: Re: Minimal logical decoding on standbys
Date: 2023-04-05 12:44:09
Message-ID: e34ab1df-573b-20c1-664a-697851fc736d@gmail.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

Hi,

On 4/5/23 12:28 PM, Amit Kapila wrote:
> On Wed, Apr 5, 2023 at 2:41 PM Drouvot, Bertrand
> <bertranddrouvot(dot)pg(at)gmail(dot)com> wrote:
>> 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.

Ack.

> 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.
>

I think this is a valid idea but I think I do prefer the current one (where the
startup process triggers the invalidations) because:

- I think this is better to invalidate as soon as possible. In case of inactive logical
replication slot (walsenders stopped) it could take time to get "notified". While with the current
approach you'd get notified in the logfile and pg_replication_slots even if walsenders are stopped.

- This is not a "slot" dependent invalidation (as opposed to the xid invalidations case)

- This is "somehow" the same behavior as on the primary: if one change the wal_level to be < logical
then the engine will not start (if logical slot in place). Then what has been decoded is until the time
the engine has been stopped. So if there is walsender lag, you'd not see some records.

> minor nitpick:
> +
> + /* Intentional fall through to session cancel */
> + /* FALLTHROUGH */
>
> Do we need to repeat fall through twice in different ways?
>

Do you mean, you'd prefer what was done in v52/0002?

Regards,

--
Bertrand Drouvot
PostgreSQL Contributors Team
RDS Open Source Databases
Amazon Web Services: https://aws.amazon.com

In response to

Responses

Browse pgsql-hackers by date

  From Date Subject
Next Message Robert Haas 2023-04-05 12:59:12 Re: Comment typo in recent push
Previous Message Amit Kapila 2023-04-05 11:59:38 Re: Minimal logical decoding on standbys