Re: [Proposal] Add foreign-server health checks infrastructure

From: Shinya Kato <Shinya11(dot)Kato(at)oss(dot)nttdata(dot)com>
To: kuroda(dot)hayato(at)fujitsu(dot)com
Cc: pgsql-hackers(at)lists(dot)postgresql(dot)org, zyu(at)yugabyte(dot)com
Subject: Re: [Proposal] Add foreign-server health checks infrastructure
Date: 2021-12-06 11:06:49
Message-ID: b9076e887ec768463428ecccf4e63a26@oss.nttdata.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

On 2021-11-29 21:36, Zhihong Yu wrote:
> On Mon, Nov 29, 2021 at 12:51 AM kuroda(dot)hayato(at)fujitsu(dot)com
> <kuroda(dot)hayato(at)fujitsu(dot)com> wrote:
>
>> Dear Zhihong,
>>
>> Thank you for giving comments! I'll post new patches later.
>>
>>> +#define HOLD_CHECKING_REMOTE_SERVERS_INTERRUPTS()
>> (CheckingRemoteServersHoldoffCount++)
>>>
>>> The macro contains only one operation. Can the macro be removed
>> (with `CheckingRemoteServersHoldoffCount++` inlined) ?
>>
>> Hmm, these HOLD/RESUME macros are followed HOLD_INTERRUPUST() and
>> HOLD_CANCEL_INTERRUPTS():
>>
>> ```
>> #define HOLD_INTERRUPTS() (InterruptHoldoffCount++)
>>
>> #define RESUME_INTERRUPTS() \
>> do { \
>> Assert(InterruptHoldoffCount > 0); \
>> InterruptHoldoffCount--; \
>> } while(0)
>>
>> #define HOLD_CANCEL_INTERRUPTS() (QueryCancelHoldoffCount++)
>>
>> #define RESUME_CANCEL_INTERRUPTS() \
>> do { \
>> Assert(QueryCancelHoldoffCount > 0); \
>> QueryCancelHoldoffCount--; \
>> } while(0)
>>
>> #define START_CRIT_SECTION() (CritSectionCount++)
>>
>> #define END_CRIT_SECTION() \
>> do { \
>> Assert(CritSectionCount > 0); \
>> CritSectionCount--; \
>> } while(0)
>> ```
>>
>> So I want to keep the current style. Could you tell me if you have
>> any other reasons?
>>
>>> + if (CheckingRemoteServersTimeoutPending &&
>> CheckingRemoteServersHoldoffCount != 0)
>>> + {
>>> + /*
>>> + * Skip checking foreign servers while reading messages.
>>> + */
>>> + InterruptPending = true;
>>> + }
>>> + else if (CheckingRemoteServersTimeoutPending)
>>>
>>> Would the code be more readable if the above two if blocks be
>> moved inside one enclosing if block (factoring the common
>> condition)?
>>>
>>> + if (CheckingRemoteServersTimeoutPending)
>>
>> +1. Will fix.
>>
>> Best Regards,
>> Hayato Kuroda
>> FUJITSU LIMITED
>
> Hi,
>
> It is Okay to keep the macros.
>
> Thanks

Hi, Kuroda-san. Sorry for late reply.

Even for local-only transaction, I thought it useless to execute
CallCheckingRemoteServersCallbacks() and enable_timeout_after(). Can I
make it so that it determines outside whether it contains SQL to the
remote or not?

The following points are minor.
1. In foreign.c, some of the lines are too long and should be broken.
2. In pqcomm.c, the newline have been removed, what is the intention of
this?
3. In postgres.c,
3-1. how about inserting a comment between lines 2713 and 2714, similar
to line 2707?
3-2. the line breaks in line 3242 and line 3243 should be aligned.
3-3. you should change
/*
* Skip checking foreign servers while reading messages.
*/
to
/*
* Skip checking foreign servers while reading messages.
*/
4. In connection.c, There is a typo in line 1684, so "fucntion" should
be changed to "function".

--
Regards,

--
Shinya Kato
Advanced Computing Technology Center
Research and Development Headquarters
NTT DATA CORPORATION

In response to

Responses

Browse pgsql-hackers by date

  From Date Subject
Next Message Michael Paquier 2021-12-06 11:15:22 Re: preserve timestamps when installing headers
Previous Message Amit Kapila 2021-12-06 10:59:06 Re: Optionally automatically disable logical replication subscriptions on error