Re: Proposal: Conflict log history table for Logical Replication

From: shveta malik <shveta(dot)malik(at)gmail(dot)com>
To: Dilip Kumar <dilipbalaut(at)gmail(dot)com>
Cc: Amit Kapila <amit(dot)kapila16(at)gmail(dot)com>, vignesh C <vignesh21(at)gmail(dot)com>, Nisha Moond <nisha(dot)moond412(at)gmail(dot)com>, Peter Smith <smithpb2250(at)gmail(dot)com>, Masahiko Sawada <sawada(dot)mshk(at)gmail(dot)com>, Bharath Rupireddy <bharath(dot)rupireddyforpostgres(at)gmail(dot)com>, PostgreSQL Hackers <pgsql-hackers(at)lists(dot)postgresql(dot)org>, shveta malik <shveta(dot)malik(at)gmail(dot)com>
Subject: Re: Proposal: Conflict log history table for Logical Replication
Date: 2026-06-11 10:34:13
Message-ID: CAJpy0uBhGT_B_SXsSKpfxh_SM3TaEGe2mpC2aYFJrnGXq9W=VA@mail.gmail.com
Views: Whole Thread | Raw Message | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

On Thu, Jun 11, 2026 at 10:44 AM Dilip Kumar <dilipbalaut(at)gmail(dot)com> wrote:
>
>
> Please find the rebased patch
> 1. It includes the new 0005 patch for reporting errors for DDLs on clt.
>
> Open comments:
> 1. Recent comments from Nisha and Shveta after v47 are still open
> 2. Vignesh's patch for "describe related" changes needs a rebase. Can
> you do that, Vignesh? Meanwhile, I will close all the open comments
> and try to share a new version by EOD today.
>

Thanks. A few comments:

1)
If I rename pg_conflict schema; apply worker handles it well as I do
not see any issue, but pg_dump starts giving problem:.

./pg_dump -d postgres -p 5434 > sub.log
pg_dump: error: query failed: ERROR: permission denied:
"pg_conflict_log_16390" is a conflict log table
DETAIL: Conflict log tables are managed by the system for logical replication.
pg_dump: detail: Query was: LOCK TABLE public.tab1,
conflict_new.pg_conflict_log_16390 IN ACCESS SHARE MODE

Can dependency on name be removed even from pg_dump to avoid above issue?

2)
+ /*
+ * Conflict log tables are used internally for logical replication conflict
+ * logging and should not be modified directly, as it could disrupt
+ * conflict logging.
+ */
+ if (IsConflictLogTableClass(classform))
+ ereport(ERROR,
+ (errcode(ERRCODE_INSUFFICIENT_PRIVILEGE),
+ errmsg("permission denied: \"%s\" is a conflict log table",
+ rv->relname),
+ errdetail("Conflict log tables are managed by the system for logical
replication.")));

The comment is too generic. Suggestion:

/*
* Disallow extended statistics on conflict log tables. These are
* internal, system-managed tables with no indexes, making
* statistics useless for planning while adding unnecessary
* catalog dependency overhead.
*/

3)
If we want to keep one generic DETAIL msg, shall it be changed to:

Conflict log tables are system-managed tables for logical replication conflicts.
~~

Will review more tomorrow.

thanks
Shveta

In response to

Browse pgsql-hackers by date

  From Date Subject
Next Message shveta malik 2026-06-11 10:37:44 Re: [PATCH] Preserve replication origin OIDs in pg_upgrade
Previous Message solai v 2026-06-11 10:31:36 Re: extend JSON_TABLE top level path expression