Re: Support logical replication of DDLs

From: vignesh C <vignesh21(at)gmail(dot)com>
To: shveta malik <shveta(dot)malik(at)gmail(dot)com>
Cc: 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>, "Wei Wang (Fujitsu)" <wangw(dot)fnst(at)fujitsu(dot)com>, Runqi Tian <runqidev(at)gmail(dot)com>, Peter Smith <smithpb2250(at)gmail(dot)com>, Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>, li jie <ggysxcq(at)gmail(dot)com>, Dilip Kumar <dilipbalaut(at)gmail(dot)com>, Alvaro Herrera <alvherre(at)alvh(dot)no-ip(dot)org>, Masahiko Sawada <sawada(dot)mshk(at)gmail(dot)com>, Japin Li <japinli(at)hotmail(dot)com>, rajesh singarapu <rajesh(dot)rs0541(at)gmail(dot)com>, PostgreSQL Hackers <pgsql-hackers(at)lists(dot)postgresql(dot)org>, Zheng Li <zhengli10(at)gmail(dot)com>
Subject: Re: Support logical replication of DDLs
Date: 2023-05-29 12:46:22
Message-ID: CALDaNm3ELSfqTi-GHuNkOqcuN12rmkR_JAquMvL+R266FZW9Ow@mail.gmail.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-general pgsql-hackers

On Wed, 24 May 2023 at 11:08, vignesh C <vignesh21(at)gmail(dot)com> wrote:
>
> On Mon, 22 May 2023 at 11:27, shveta malik <shveta(dot)malik(at)gmail(dot)com> wrote:
> >
> > On Wed, May 17, 2023 at 4:45 PM vignesh C <vignesh21(at)gmail(dot)com> wrote:
> > >
> > > On Wed, 17 May 2023 at 15:41, shveta malik <shveta(dot)malik(at)gmail(dot)com> wrote:
> > > >
> > > > On Fri, May 12, 2023 at 12:03 PM shveta malik <shveta(dot)malik(at)gmail(dot)com> wrote:
> > > > >
> > > > > On Tue, May 9, 2023 at 4:23 PM shveta malik <shveta(dot)malik(at)gmail(dot)com> wrote:
> > > > > >
> > > > > > On Mon, May 8, 2023 at 4:31 PM shveta malik <shveta(dot)malik(at)gmail(dot)com> wrote:
> > > > > > >
> > > > > > > On Mon, May 8, 2023 at 3:58 PM shveta malik <shveta(dot)malik(at)gmail(dot)com> wrote:
> > > > > > > >
> > > > > > > > On Tue, May 2, 2023 at 8:30 AM shveta malik <shveta(dot)malik(at)gmail(dot)com> wrote:
> > > > > > > > >
> > > > > > > > > On Fri, Apr 28, 2023 at 5:11 PM Amit Kapila <amit(dot)kapila16(at)gmail(dot)com> wrote:
> > > > > > > > > >
> > > > > > > > > > Now, I think we can try to eliminate this entire ObjTree machinery and
> > > > > > > > > > directly from the JSON blob during deparsing. We have previously also
> > > > > > > > > > discussed this in an email chain at [1]. I think now the functionality
> > > > > > > > > > of JSONB has also been improved and we should investigate whether it
> > > > > > > > > > is feasible to directly use JSONB APIs to form the required blob.
> > > > > > > > >
> > > > > > > > > +1.
> > > > > > > > > I will investigate this and will share my findings.
> > > > > > > > >
> > > > > > > >
> > > > > > > >
> > > > > > > > Please find the PoC patch for create-table after object-tree removal.
> > > > > > >
> > > > > >
> > > > >
> > > > > Please find the new set of patches attached for object-tree removal.
> > > >
> > > > Please find the new set of patches for object-tree Removal. The new
> > > > changes are in patch 0008 only. The new changes incorporate the
> > > > object-tree removal for 'alter table' command.
> > >
> >
> > Please find the new set of patches for object-tree Removal. The new
> > changes are in patch 0008 only. The new changes address object tree
> > removal for below commands.
> >
> > create sequence
> > alter sequence
> > alter object owner to
> > alter object set schema
> > alter object rename
> >
> > In this patch 0008, ddldeparse.c is now object-tree free for all the
> > table related commands. Index related commands are yet to be done.
>
> I found few comments while making some changes to the patch:
> 1) Now that objtree is removed, these comments should be modified:
> * Deparse object tree is created by using:
> * a) new_objtree("know contents") where the complete tree content is known or
> * the initial tree content is known.
> * b) new_objtree("") for the syntax where the object tree will be derived
> * based on some conditional checks.
> * c) new_objtree_VA where the complete tree can be derived using some fixed
> * content or by using the initial tree content along with some variable
> * arguments.
> *

Modified

> 2) isgrant can be removed as it is not used anymore:
> +/*
> + * Return the given object type as a string.
> + *
> + * If isgrant is true, then this function is called while deparsing GRANT
> + * statement and some object names are replaced.
> + */
> +const char *
> +stringify_objtype(ObjectType objtype, bool isgrant)
> +{
> + switch (objtype)
> + {
> + case OBJECT_TABLE:
> + return "TABLE";
> + default:
> + elog(ERROR, "unsupported object type %d", objtype);
> + }
> +
> + return "???"; /* keep compiler quiet */
> +}

Modified

> 3) This statement is not being handled currently, it should be implemented:
> "alter table all in tablespace tbs1 set tablespace"

Modified

> 4) This pub_ddl is selected as the 7th column, it should be 7 instead of 9 here:
> @@ -6405,6 +6418,8 @@ describePublications(const char *pattern)
> printTableAddCell(&cont, PQgetvalue(res, i, 4), false, false);
> printTableAddCell(&cont, PQgetvalue(res, i, 5), false, false);
> printTableAddCell(&cont, PQgetvalue(res, i, 6), false, false);
> + if (has_pubddl)
> + printTableAddCell(&cont, PQgetvalue(res, i,
> 9), false, false);
> if (has_pubtruncate)
> printTableAddCell(&cont, PQgetvalue(res, i,
> 7), false, false);
> if (has_pubviaroot)

Modified

The following patches were changed to fix the above issues: 1)
0001-Deparser-for-Table-DDL-commands-and-extending-event-2023_05_29.patch
2) 0005-DDL-replication-for-Table-DDL-commands-2023_05_29.patch and 3)
0008-ObjTree-Removal-for-multiple-commands-2023_05_29.patch

The attached patch has the changes for the same.

Regards,
Vignesh

Attachment Content-Type Size
0002-Enhance-the-event-trigger-to-support-DDL-deparsing-2023_05_29.patch text/x-patch 33.9 KB
0003-Add-verbose-option-for-ddl-deparse-module-2023_05_29.patch text/x-patch 47.1 KB
0001-Deparser-for-Table-DDL-commands-and-extending-event-2023_05_29.patch text/x-patch 167.3 KB
0005-DDL-replication-for-Table-DDL-commands-2023_05_29.patch text/x-patch 248.2 KB
0004-Introduce-the-test_ddl_deparse_regress-test-module-2023_05_29.patch text/x-patch 977.8 KB
0006-Add-subscription-tap-test-for-DDL-replication-for-TA-2023_05_29.patch text/x-patch 20.8 KB
0007-Apply-the-DDL-change-as-that-same-user-that-executed-2023_05_29.patch text/x-patch 60.0 KB
0008-ObjTree-Removal-for-multiple-commands-2023_05_29.patch text/x-patch 1.7 MB

In response to

Responses

Browse pgsql-general by date

  From Date Subject
Next Message Arquimedes Aguirre 2023-05-29 16:45:21 RE: FW: Error!
Previous Message Albert Praveen 2023-05-29 06:18:12 SSPI authentication failed for user "xxx"

Browse pgsql-hackers by date

  From Date Subject
Next Message Giuseppe Broccolo 2023-05-29 13:18:03 Re: vector search support
Previous Message Drouvot, Bertrand 2023-05-29 12:31:24 Re: BF animal dikkop reported a failure in 035_standby_logical_decoding