Re: Introduce XID age and inactive timeout based replication slot invalidation

From: Nisha Moond <nisha(dot)moond412(at)gmail(dot)com>
To: "Zhijie Hou (Fujitsu)" <houzj(dot)fnst(at)fujitsu(dot)com>
Cc: Amit Kapila <amit(dot)kapila16(at)gmail(dot)com>, vignesh C <vignesh21(at)gmail(dot)com>, Shlok Kyal <shlok(dot)kyal(dot)oss(at)gmail(dot)com>, "Hayato Kuroda (Fujitsu)" <kuroda(dot)hayato(at)fujitsu(dot)com>, shveta malik <shveta(dot)malik(at)gmail(dot)com>, Bharath Rupireddy <bharath(dot)rupireddyforpostgres(at)gmail(dot)com>, Ajin Cherian <itsajin(at)gmail(dot)com>, Bertrand Drouvot <bertranddrouvot(dot)pg(at)gmail(dot)com>, Masahiko Sawada <sawada(dot)mshk(at)gmail(dot)com>, Nathan Bossart <nathandbossart(at)gmail(dot)com>, PostgreSQL Hackers <pgsql-hackers(at)lists(dot)postgresql(dot)org>, Peter Smith <smithpb2250(at)gmail(dot)com>
Subject: Re: Introduce XID age and inactive timeout based replication slot invalidation
Date: 2025-02-10 12:03:07
Message-ID: CABdArM57P4HkGHdz-FM8bY0txDgiKi5BA073MJWKeoZVuKsU+w@mail.gmail.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

On Sat, Feb 8, 2025 at 12:28 PM Zhijie Hou (Fujitsu)
<houzj(dot)fnst(at)fujitsu(dot)com> wrote:
>
> On Friday, February 7, 2025 9:06 PM Nisha Moond <nisha(dot)moond412(at)gmail(dot)com> wrote:
> >
> > Attached v72 patches, addressed the above comments as well as Vignesh's
> > comments in [2].
> > - There are no new changes in patch-002.
>
> Thanks for updating the patch, I have few review comments:
>
> 1.
> > InvalidateObsoleteReplicationSlots(ReplicationSlotInvalidationCause cause,
>
> I think the type of first parameter 'cause' is not appropriate anymore since
> it's now a bitmap flag instead of an enum.
>

Changed the type to 'int' and updated the name of 'cause' in both
InvalidateObsoleteReplicationSlots() and
InvalidatePossiblyObsoleteSlot(), as both now use the bitmap flag.

> 2.
> > -StaticAssertDecl(lengthof(SlotInvalidationCauses) == (RS_INVAL_MAX_CAUSES + 1),
> > - "array length mismatch");
> > +#define RS_INVAL_MAX_CAUSES (sizeof(InvalidationCauses) / sizeof(InvalidationCauses[0]))
>
> I'd like to confirm if the current value of the RS_INVAL_MAX_CAUSES is correct.
> Previously, the value is arrary_length - 1, while now it seems equal to the
> arrary_length.
>
> And ISTM we could directly call lengthof() here.
>

Done.

> 3.
>
> + if (cause & RS_INVAL_HORIZON)
> + {
> + if (!SlotIsLogical(s))
> + goto invalidation_marked;
>
> I am not sure if this logic is correct. Even if the slot would not be
> invalidated due to RS_INVAL_HORIZON, we should continue to check other causes.
>

Used goto here since we do not expect RS_INVAL_HORIZON to be combined
with any other "cause" and to keep the pgHead behavior.
However, with the bitflag approach, the code should be future-safe, so
replacing goto in v73 should handle this now.

> Besides, instead of using a goto, I personally prefer to move all these codes
> into a separate function which would return a single invalidation cause.
>

Done.

~~~~
Here are the v73 patches incorporating the comments above and the
subsequent comments from [1].
- patch 002 is rebased on 001 with no new changes.

[1] https://www.postgresql.org/message-id/CAA4eK1K%2BAMtGfD3WRK_ivdAeS-CBOUBKJbr-6ku175P1x%3Dwk4g%40mail.gmail.com

--
Thanks,
Nisha

Attachment Content-Type Size
v73-0001-Introduce-inactive_timeout-based-replication-slo.patch application/octet-stream 30.2 KB
v73-0002-Add-TAP-test-for-slot-invalidation-based-on-inac.patch application/octet-stream 6.5 KB

In response to

Responses

Browse pgsql-hackers by date

  From Date Subject
Next Message Amit Kapila 2025-02-10 12:11:08 Re: Fix assert failure when decoding XLOG_PARAMETER_CHANGE on primary
Previous Message torikoshia 2025-02-10 12:02:56 Re: Enhancing Memory Context Statistics Reporting