| 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: | Whole Thread | Raw Message | 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 | 
| 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 |