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-20 11:17:45
Message-ID: OS0PR01MB5716800E7C5FD89E777DD934947CA@OS0PR01MB5716.jpnprd01.prod.outlook.com
Views: Whole Thread | Raw Message | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

On Fri, Jun 20, 2025 at 3:22 PM shveta malik wrote:
>
> On Thu, Jun 19, 2025 at 4:34 PM shveta malik <shveta(dot)malik(at)gmail(dot)com>
> wrote:
> >
> > >
> > > Here is the V38 patch set which includes the following changes:
> > >
> >
> > Thank You for the patches. Few comments:
> >
> > 1)
> > + <para>
> > + Note that commit timestamps and origin data retained by enabling the
> > + <link
> linkend="sql-createsubscription-params-with-retain-conflict-info"><literal
> >retain_conflict_info</literal></link>
> > + option will not be preserved during the upgrade. As a
> > + result, the upgraded subscriber might be unable to detect conflicts or
> log
> > + relevant commit timestamps and origins when applying changes from
> the
> > + publisher occurring during the upgrade.
> > + </para>
> >
> > This statement is true even for changes pending from 'before' the
> > upgrade. So we shall change last line where we mention 'during the
> > upgrade'

Changed.

> >
> > 2)
> > + <para>
> > + Note that the information for conflict detection cannot be purged
> if
> > + the subscription is disabled; thus, the information will
> accumulate
> > + until the subscription is enabled. To prevent excessive
> accumulation,
> > + it is recommended to disable
> <literal>retain_conflict_info</literal>
> > + if the subscription will be inactive for an extended period.
> > + </para>
> >
> > I think this can be put in WARNING or CAUTION tags as this is
> > something which if neglected can result in system bloat.

Agreed, I chose CAUTION since the replication slot page[1]
is using the same for the risk of WAL bloat.

> >
> > 3)
> > postgres=# create subscription sub3 connection 'dbname=postgres
> > host=localhost user=shveta port=5433' publication pub2 WITH (failover
> > = true, retain_conflict_info = true);
> > WARNING: commit timestamp and origin data required for detecting
> > conflicts won't be retained
> > HINT: Consider setting "track_commit_timestamp" to true.
> > ERROR: subscription "sub3" already exists
> >
> > In CreateSubscription(), we shall move CheckSubConflictInfoRetention()
> > after sub-duplicity check. Above WARNING with the existing-sub ERROR
> > looks odd.

Changed.

> >
> > 4)
> > In check_new_cluster_replication_slots(), earlier we were not doing
> > any checks for 'count of logical slots on new cluster' if there were
> > no logical slots on old cluster (i.e. nslots_on_old is 0). Now we are
> > doing a 'nslots_on_new' related check even when 'nslots_on_old' is 0
> > for the case when RCI is enabled. Shouldn't we skip 'nslots_on_new'
> > check when 'nslots_on_old' is 0?

I agreed. In addition, I have also added a check to confirm the reserved
replication slot pg_conflict_detection does not exist on the new cluster
when migrating subscriptions with retain_conflict_info enabled.

> >
> > 5)
> > We refer to 'update_deleted' in patch1's comment when the conflict is
> > not yet created. Is it okay?

Moved to later patches where update_deleted is supported.

> >
>
> Please find few more comments:
>
> 6)
> We can add in doc that pg_conflict_detection is a physical slot with no
> wals-reserved.

I added the physical mark. Since we have explicitly mention the info we are
retaining, I didn't mention WAL in this version.

>
> 7)
> We shall error or give warning (whatever appropriate) in
> ReplicationSlotAcquire() (similar to ReplicationSlotValidateName()), that if it is
> pg_conflict_detection slot, then acquire is possible only if the process is
> launcher. This will prevent:
>
> a) manual/accidental drop of slot by user before launcher could acquire it.
> b) usage of slot in primary_slot_name before launcher could acquire it.
>
> It will also make lot-advance error more meaningful. Currently it gives below
> error:
>
> postgres=# select pg_replication_slot_advance ('pg_conflict_detection',
> pg_current_wal_lsn());
> ERROR: replication slot "pg_conflict_detection" cannot be advanced
> DETAIL: This slot has never previously reserved WAL, or it has been
> invalidated.

Added a new error message in slot acquisition as suggested.

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

0001:
* Addressed the comments above.

0002:
* Addressed the comments above.
* Improved some comments and documentation additionally.

0003:
A new patch to migrate the conflict detection during upgrade. (Suggested by Amit[2])

0004:
Rebased

0005:
Rebased

0006:
Rebased

0007:
Rebased

0008:
Rebased

[1] https://www.postgresql.org/docs/devel/warm-standby.html#STREAMING-REPLICATION-SLOTS
[2] https://www.postgresql.org/message-id/CAA4eK1%2ByP3%2B4CRtkqPEn5DgsaQXJogep4QyqTVSaqk%3DouGqQEQ%40mail.gmail.com

Best Regards,
Hou zj

Attachment Content-Type Size
v39-0008-Allow-altering-retain_conflict_info-for-enabled-.patch application/octet-stream 28.5 KB
v39-0001-Retain-the-information-useful-for-detecting-conf.patch application/octet-stream 63.2 KB
v39-0002-Add-a-retain_conflict_info-option-to-subscriptio.patch application/octet-stream 103.7 KB
v39-0003-Migrate-the-conflict-detection-slot-to-the-new-n.patch application/octet-stream 12.3 KB
v39-0004-Introduce-a-new-GUC-max_conflict_retention_durat.patch application/octet-stream 29.3 KB
v39-0005-Re-create-the-replication-slot-if-the-conflict-r.patch application/octet-stream 7.0 KB
v39-0006-Add-a-tap-test-to-verify-the-management-of-the-n.patch application/octet-stream 8.0 KB
v39-0007-Support-the-conflict-detection-for-update_delete.patch application/octet-stream 29.4 KB

In response to

Responses

Browse pgsql-hackers by date

  From Date Subject
Next Message Rahila Syed 2025-06-20 11:23:52 Re: add function for creating/attaching hash table in DSM registry
Previous Message Tatsuro Yamada 2025-06-20 10:34:40 Re: Add enable_groupagg GUC parameter to control GroupAggregate usage