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 |
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 |