Re: synchronized_standby_slots behavior inconsistent with quorum-based synchronous replication

From: Ashutosh Sharma <ashu(dot)coek88(at)gmail(dot)com>
To: shveta malik <shveta(dot)malik(at)gmail(dot)com>
Cc: Shlok Kyal <shlok(dot)kyal(dot)oss(at)gmail(dot)com>, Amit Kapila <amit(dot)kapila16(at)gmail(dot)com>, "Zhijie Hou (Fujitsu)" <houzj(dot)fnst(at)fujitsu(dot)com>, Ajin Cherian <itsajin(at)gmail(dot)com>, SATYANARAYANA NARLAPURAM <satyanarlapuram(at)gmail(dot)com>, PostgreSQL-development <pgsql-hackers(at)postgresql(dot)org>, PostgreSQL Hackers <pgsql-hackers(at)lists(dot)postgresql(dot)org>
Subject: Re: synchronized_standby_slots behavior inconsistent with quorum-based synchronous replication
Date: 2026-06-18 07:12:08
Message-ID: CAE9k0Pkk5VeFgN7jWiG_82oVRfON8LhBRofAbQ+rN8C2QrvP1g@mail.gmail.com
Views: Whole Thread | Raw Message | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

Hi Shveta,

Thanks again for your review comments, please find my responses inline below:

On Thu, Jun 18, 2026 at 11:14 AM shveta malik <shveta(dot)malik(at)gmail(dot)com> wrote:
>
> 1)
> +
> +# FIRST duplicates must also not create extra priority positions.
> +$primary->adjust_conf('postgresql.conf', 'synchronized_standby_slots',
> + "'FIRST 2 (sb1_slot, sb1_slot, sb2_slot)'");
> +$primary->reload;
>
> I think either of ANY or FIRST is enough to cover the duplicate
> removal path. We can remove any one of these tests if you agree.
>

It can be. From a code coverage perspective, I don't see any impact.
However, FIRST and ANY represent different semantics. Although they
share the same underlying logic for filtering duplicate entries, I
felt it would still be beneficial to have a test case that explicitly
demonstrates that duplicate removal works correctly with both options.

That said, if you feel this makes the test file a bit heavier than
necessary, I'm happy to remove it and keep the test suite lighter.

> 2)
> I tried running tests. Ran it 6 times. 3 times, it finished in 7-8
> seconds, while in the rest of the runs, it took 25 seconds each.
>
> Please run this on your machine and let me know if the behaviour is same.
>
> In the log file of the run (and other similar runs), where execution
> time is longer, most of the time is spent here:
>
> primary.log:
> 2026-06-18 10:50:03.687 IST postmaster[49574] LOG: received SIGHUP,
> reloading configuration files
> 2026-06-18 10:50:03.688 IST postmaster[49574] LOG: parameter
> "synchronized_standby_slots" changed to ""
> 2026-06-18 10:50:21.514 IST walsender[49792]
> 054_synchronized_standby_slots_quorum.pl LOG: released physical
> replication slot "sb1_slot"
> 2026-06-18 10:50:21.522 IST client backend[49801]
> 054_synchronized_standby_slots_quorum.pl LOG: statement: SELECT
> pg_logical_slot_get_changes('logical_failover', NULL, NULL);
>
> Standby's log:
> 2026-06-18 10:50:02.470 IST client backend[49768]
> 054_synchronized_standby_slots_quorum.pl LOG: statement: WAIT FOR LSN
> '0/030003C8' WITH (MODE 'standby_replay', timeout '180s', no_throw);
> 2026-06-18 10:50:03.644 IST client backend[49790]
> 054_synchronized_standby_slots_quorum.pl LOG: statement: WAIT FOR LSN
> '0/03000448' WITH (MODE 'standby_replay', timeout '180s', no_throw);
> 2026-06-18 10:50:21.696 IST postmaster[49614] LOG: received fast
> shutdown request
> ~~
>
> Notice the time jump from '10:50:02' to ' 10:50:21'
>

I ran the test case 7–8 times, and each execution completed in roughly
6–9 seconds on my machine. Please check the attached file with test
results.

--
With Regards,
Ashutosh Sharma.

Attachment Content-Type Size
test_results_synchronized_standby_slots.txt text/plain 2.3 KB

In response to

Browse pgsql-hackers by date

  From Date Subject
Next Message Alexander Korotkov 2026-06-18 07:31:11 Re: Add SPLIT PARTITION/MERGE PARTITIONS commands
Previous Message Chao Li 2026-06-18 06:46:04 Re: Fix tuple deformation with virtual generated NOT NULL columns