Re: [HACKERS] logical decoding of two-phase transactions

From: Ajin Cherian <itsajin(at)gmail(dot)com>
To: vignesh C <vignesh21(at)gmail(dot)com>
Cc: Greg Nancarrow <gregn4422(at)gmail(dot)com>, Peter Smith <smithpb2250(at)gmail(dot)com>, Amit Kapila <amit(dot)kapila16(at)gmail(dot)com>, "tanghy(dot)fnst(at)fujitsu(dot)com" <tanghy(dot)fnst(at)fujitsu(dot)com>, PostgreSQL Hackers <pgsql-hackers(at)postgresql(dot)org>
Subject: Re: [HACKERS] logical decoding of two-phase transactions
Date: 2021-06-23 10:40:46
Message-ID: CAFPTHDb+Ph1rx7nQHJHTyFEYtNENPEo9s5ku760Uo3j9g3-rfQ@mail.gmail.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

On Wed, Jun 23, 2021 at 3:18 PM vignesh C <vignesh21(at)gmail(dot)com> wrote:

> Thanks for the updated patch.
> The patch v89-0001-Add-option-to-set-two-phase-in-CREATE_REPLICATIO.patch
> has the following:
> + <term><literal>TWO_PHASE</literal></term>
> + <listitem>
> + <para>
> + Specify that this logical replication slot supports decoding
> of two-phase
> + transactions. With this option, two-phase commands like
> + <literal>PREPARE TRANSACTION</literal>, <literal>COMMIT
> PREPARED</literal>
> + and <literal>ROLLBACK PREPARED</literal> are decoded and transmitted.
> + The transaction will be decoded and transmitted at
> + <literal>PREPARE TRANSACTION</literal> time.
> + </para>
> + </listitem>
> + </varlistentry>
>
> The patch v89-0003-Add-support-for-prepared-transactions-to-built-i.patch
> has the following:
> + <term><literal>TWO_PHASE</literal></term>
> + <listitem>
> + <para>
> + Specify that this replication slot supports decode of two-phase
> + transactions. With this option, two-phase commands like
> + <literal>PREPARE TRANSACTION</literal>, <literal>COMMIT
> PREPARED</literal>
> + and <literal>ROLLBACK PREPARED</literal> are decoded and transmitted.
> + The transaction will be decoded and transmitted at
> + <literal>PREPARE TRANSACTION</literal> time.
> + </para>
> + </listitem>
> + </varlistentry>
>
> We can remove one of them.

I missed this. Updated.

Also fixed this comment below which I had missed in my last patch:

>4) You could mention "Before you use two-phase commit commands, you
>must set max_prepared_transactions to at least 1" for example 2.
> $ pg_recvlogical -d postgres --slot=test --drop-slot
>+
>+$ pg_recvlogical -d postgres --slot=test --create-slot --two-phase
>+$ pg_recvlogical -d postgres --slot=test --start -f -

Comment 6:
>6) This should be before verbose, the options are printed alphabetically
> printf(_(" -v, --verbose output verbose messages\n"));
>+ printf(_(" -t, --two-phase enable two-phase decoding
>when creating a slot\n"));
> printf(_(" -V, --version output version information,
>then exit\n"));

This was also fixed in the last patch.

regards,
Ajin Cherian
Fujitsu Australia

Attachment Content-Type Size
v90-0004-Add-prepare-API-support-for-streaming-transactio.patch application/octet-stream 54.1 KB
v90-0001-Add-option-to-set-two-phase-in-CREATE_REPLICATIO.patch application/octet-stream 6.5 KB
v90-0002-Add-support-for-two-phase-decoding-in-pg_recvlog.patch application/octet-stream 11.5 KB
v90-0005-Skip-empty-transactions-for-logical-replication.patch application/octet-stream 27.5 KB
v90-0003-Add-support-for-prepared-transactions-to-built-i.patch application/octet-stream 146.2 KB

In response to

Responses

Browse pgsql-hackers by date

  From Date Subject
Next Message Boris Kolpackov 2021-06-23 11:03:52 Re: Pipeline mode and PQpipelineSync()
Previous Message Fabien COELHO 2021-06-23 09:37:58 Re: pgbench logging broken by time logic changes