RE: Conflict detection for update_deleted in logical replication

From: "Zhijie Hou (Fujitsu)" <houzj(dot)fnst(at)fujitsu(dot)com>
To: shveta malik <shveta(dot)malik(at)gmail(dot)com>
Cc: Amit Kapila <amit(dot)kapila16(at)gmail(dot)com>, vignesh C <vignesh21(at)gmail(dot)com>, Masahiko Sawada <sawada(dot)mshk(at)gmail(dot)com>, Nisha Moond <nisha(dot)moond412(at)gmail(dot)com>, "Hayato Kuroda (Fujitsu)" <kuroda(dot)hayato(at)fujitsu(dot)com>, pgsql-hackers <pgsql-hackers(at)postgresql(dot)org>
Subject: RE: Conflict detection for update_deleted in logical replication
Date: 2025-06-12 06:04:41
Message-ID: OS0PR01MB57164162B311FAB059DA5DD19474A@OS0PR01MB5716.jpnprd01.prod.outlook.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

On Wed, Jun 11, 2025 at 5:34 PM shveta malik wrote:
>
> On Tue, Jun 10, 2025 at 11:55 AM Zhijie Hou (Fujitsu)
> <houzj(dot)fnst(at)fujitsu(dot)com> wrote:
> >
> > Here is the V35 patch set which includes the following changes:
> >
>
> Thank You for the patches, few comments:

Thanks for the comments!

>
> 1)
> compute_min_nonremovable_xid:
>
> + /*
> + * Stop advancing xmin if an invalid non-removable transaction ID is
> + * found, otherwise update xmin.
> + */
> + if (!TransactionIdIsValid(nonremovable_xid))
> + *can_advance_xmin = false;
>
> IMO, we can not have invalid nonremovable_xid here. It may be a possibility in
> a later patch where we do stop-conflict-detection for a worker and resets
> nonremovable_xid to Invalid. But in patch003, should this rather be an Assert
> as we want to ensure that worker's oldest is set to slot's-xmin by this time.

Agreed. I have removed the check and added an Assert.

>
> 2)
> postgres=# create subscription sub1 connection 'dbname=postgres
> host=localhost user=shveta port=5433' publication pub1 WITH
> (retain_conflict_info = true);
> NOTICE: deleted rows will continue to accumulate for detecting conflicts
> until the subscription is enabled
> NOTICE: created replication slot "sub1" on publisher CREATE
> SUBSCRIPTION
>
> postgres=# alter subscription sub2 enable;
> NOTICE: deleted rows will continue to accumulate for detecting conflicts
> until the subscription is enabled
>
> We should not have this 'NOTICE: deleted rows' in above 2 commands.

Agreed, It was a miss. After thinking more, I have modified the patch to report
the NOTICE only when altering the retain_conflict_info for disabled
subscription as that aligns with the original intent for introducing the
NOTICE.

>
>
> 3)
> +
> +ALTER SUBSCRIPTION regress_testsub SET (slot_name = NONE); DROP
> +SUBSCRIPTION regress_testsub;
>
> Shall we enable regress_testsub as well before we drop it to catch unexpected
> notices/warnings if any?

I have added the ENABLE test in the tap-test in 0005, because we do not have a
valid connection for subscriptions created in subscription.sql, So enabling the
sub here could cause network error with random socket info, making the test
unstable.

>
>
> 4)
> postgres=# alter subscription sub2 disable;
> WARNING: commit timestamp and origin data required for detecting conflicts
> won't be retained
> HINT: Consider setting "track_commit_timestamp" to true.
>
> Do we need "track_commit_timestamp" related WARNING while disabling rci
> sub as well? I feel it should be there while enabling it alone.

Changed as suggested.

Here is the V35 patch set which includes the following changes:

0001:
Merged original V35-0001 and 0002.

0002:
* Addressed the comments above.
* The launcher will now attempt to acquire the conflict detection slot
initially, allowing us to determine its existence by checking if
MyReplicationSlot is NULL.
* Merged the top-up patch provided by Amit[1].

0003:
Rebased

0004:
Rebased

0005:
Added few tests to verify the WANRINGs and NOTCE.

0006:
Rebased

0007:
Rebased

Best Regards,
Hou zj

Attachment Content-Type Size
v36-0007-Allow-altering-retain_conflict_info-for-enabled-.patch application/octet-stream 28.4 KB
v36-0001-Retain-the-information-useful-for-detecting-conf.patch application/octet-stream 62.8 KB
v36-0002-Add-a-retain_conflict_info-option-to-subscriptio.patch application/octet-stream 100.6 KB
v36-0003-Introduce-a-new-GUC-max_conflict_retention_durat.patch application/octet-stream 29.1 KB
v36-0004-Re-create-the-replication-slot-if-the-conflict-r.patch application/octet-stream 6.1 KB
v36-0005-Add-a-tap-test-to-verify-the-management-of-the-n.patch application/octet-stream 8.0 KB
v36-0006-Support-the-conflict-detection-for-update_delete.patch application/octet-stream 25.7 KB

In response to

Responses

Browse pgsql-hackers by date

  From Date Subject
Next Message Noboru Saito 2025-06-12 06:13:12 Re: [PATCH] Proposal: Improvements to PDF stylesheet and table column widths
Previous Message Jeff Davis 2025-06-12 05:49:17 Re: Collation & ctype method table, and extension hooks