From: | "osumi(dot)takamichi(at)fujitsu(dot)com" <osumi(dot)takamichi(at)fujitsu(dot)com> |
---|---|
To: | 'Greg Nancarrow' <gregn4422(at)gmail(dot)com> |
Cc: | vignesh C <vignesh21(at)gmail(dot)com>, Masahiko Sawada <sawada(dot)mshk(at)gmail(dot)com>, Mark Dilger <mark(dot)dilger(at)enterprisedb(dot)com>, Amit Kapila <amit(dot)kapila16(at)gmail(dot)com>, "Smith, Peter" <peters(at)fast(dot)au(dot)fujitsu(dot)com>, PostgreSQL Hackers <pgsql-hackers(at)lists(dot)postgresql(dot)org> |
Subject: | RE: Optionally automatically disable logical replication subscriptions on error |
Date: | 2021-11-16 07:59:36 |
Message-ID: | TYCPR01MB83735B5D0AF9C872E9672507ED999@TYCPR01MB8373.jpnprd01.prod.outlook.com |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-hackers |
Thank you for checking the patch !
On Friday, November 12, 2021 1:49 PM Greg Nancarrow <gregn4422(at)gmail(dot)com> wrote:
> On Thu, Nov 11, 2021 at 8:20 PM osumi(dot)takamichi(at)fujitsu(dot)com
> <osumi(dot)takamichi(at)fujitsu(dot)com> wrote:
> Some comments on the v4 patch:
>
> (1) Patch subject
> I think the patch subject should say "disable" instead of "disabling":
> Optionally disable subscriptions on error
Fixed.
> doc/src/sgml/ref/create_subscription.sgml
> (2) spelling mistake
> + if replicating data from the publisher triggers
> + non-transicent errors
>
> non-transicent -> non-transient
Fixed.
> (I notice Vignesh also pointed this out)
>
> src/backend/replication/logical/worker.c
> (3) calling geterrcode()
> The new IsSubscriptionDisablingError() function calls geterrcode().
> According to the function comment for geterrcode(), it is only intended for use
> in error callbacks.
> Instead of calling geterrcode(), couldn't the ErrorData from PG_CATCH block be
> passed to IsSubscriptionDisablingError() instead (from which it can get the
> sqlerrcode)?
>
> (4) DisableSubscriptionOnError
> DisableSubscriptionOnError() is again calling MemoryContextSwitch() and
> CopyErrorData().
> I think the ErrorData from the PG_CATCH block could simply be passed to
> DisableSubscriptionOnError() instead of the memory-context, and the existing
> MemoryContextSwitch() and CopyErrorData() calls could be removed from it.
>
> AFAICS, applying (3) and (4) above would make the code a lot cleaner.
Fixed.
The updated patch is shared in [1].
Best Regards,
Takamichi Osumi
From | Date | Subject | |
---|---|---|---|
Next Message | Greg Nancarrow | 2021-11-16 08:23:56 | Re: row filtering for logical replication |
Previous Message | osumi.takamichi@fujitsu.com | 2021-11-16 07:53:23 | RE: Optionally automatically disable logical replication subscriptions on error |