Re: Minimal logical decoding on standbys

From: "Drouvot, Bertrand" <bdrouvot(at)amazon(dot)com>
To: Alvaro Herrera <alvherre(at)2ndquadrant(dot)com>, Andres Freund <andres(at)anarazel(dot)de>
Cc: Ibrar Ahmed <ibrar(dot)ahmad(at)gmail(dot)com>, Amit Khandekar <amitdkhan(dot)pg(at)gmail(dot)com>, <fabriziomello(at)gmail(dot)com>, tushar <tushar(dot)ahuja(at)enterprisedb(dot)com>, "[pgdg] Robert Haas" <robertmhaas(at)gmail(dot)com>, Rahila Syed <rahila(dot)syed(at)2ndquadrant(dot)com>, pgsql-hackers <pgsql-hackers(at)postgresql(dot)org>
Subject: Re: Minimal logical decoding on standbys
Date: 2021-10-27 06:55:45
Message-ID: 688cbedf-a172-f0d8-8352-d4ea223bceeb@amazon.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

Hi,

On 9/15/21 1:36 PM, Drouvot, Bertrand wrote:
>
> Hi,
>
> On 9/9/21 9:17 AM, Drouvot, Bertrand wrote:
>>
>> Hi Alvaro,
>>
>> On 8/2/21 4:56 PM, Drouvot, Bertrand wrote:
>>> Hi Alvaro,
>>>
>>> On 7/28/21 5:26 PM, Alvaro Herrera wrote:
>>>> On 2021-Jul-27, Drouvot, Bertrand wrote:
>>>>
>>>>> diff --git a/src/backend/utils/cache/lsyscache.c
>>>>> b/src/backend/utils/cache/lsyscache.c
>>>>> +bool
>>>>> +get_rel_logical_catalog(Oid relid)
>>>>> +{
>>>>> +     bool    res;
>>>>> +     Relation rel;
>>>>> +
>>>>> +     /* assume previously locked */
>>>>> +     rel = table_open(relid, NoLock);
>>>>> +     res = RelationIsAccessibleInLogicalDecoding(rel);
>>>>> +     table_close(rel, NoLock);
>>>>> +
>>>>> +     return res;
>>>>> +}
>>>> So RelationIsAccessibleInLogicalDecoding() does a cheap check for
>>>> wal_level which can be done without opening the table; I think this
>>>> function should be rearranged to avoid doing that when not needed.
>>>
>>> Thanks for looking at it.
>>>
>>>
>>>> Also, putting this function in lsyscache.c seems somewhat wrong since
>>>> it's not merely accessing the system caches ...
>>>>
>>>> I think it would be better to move this elsewhere (relcache.c,
>>>> proto in
>>>> relcache.h, perhaps call it
>>>> RelationIdIsAccessibleInLogicalDecoding) and
>>>> short-circuit for the check that can be done before opening the table.
>>
>> So you have in mind to check for XLogLogicalInfoActive() first, and
>> if true, then open the relation and call
>> RelationIsAccessibleInLogicalDecoding()?
>>
>> If so, then what about also creating a new
>> RelationIsAccessibleWhileLogicalWalLevel() or something like this
>> doing the same as RelationIsAccessibleInLogicalDecoding() but without
>> the XLogLogicalInfoActive() check?
>>
>>>> At least the GiST code appears to be able to call this several
>>>> times per
>>>> vacuum run, so it makes sense to short-circuit it for the fast case.
>>>>
>>>> ... though looking at the GiST code again I wonder if it would be more
>>>> sensible to just stash the table's Relation pointer somewhere in the
>>>> context structs
>>
>> Do you have a "good place" in mind?
>>
> Another rebase attached.
>
> The patch proposal to address Andre's walsender corner cases is still
> a dedicated commit (as i think it may be easier to discuss).
>
Another rebase attached (mainly to fix TAP tests failing due to b3b4d8e68a).

@Andres, the patch file number 6 contains an attempt to fix the
Walsender corner case you pointed out.

@Alvaro, I did not look at your remark yet. Do you have a "good place"
in mind? (related to "just stash the table's Relation pointer somewhere
in the context structs")

Given the size of this patch series, I'm wondering if we could start
committing piece per piece (while still working on the corner cases in
parallel).

That would maximize the amount of coverage it gets in the v15
development cycle.

What do you think?

Thanks

Bertrand

Attachment Content-Type Size
v25-0001-Add-info-in-WAL-records-in-preparation-for-logic.patch text/plain 18.0 KB
v25-0002-Handle-logical-slot-conflicts-on-standby.patch text/plain 29.3 KB
v25-0003-Allow-logical-decoding-on-standby.patch text/plain 17.5 KB
v25-0004-New-TAP-test-for-logical-decoding-on-standby.patch text/plain 20.0 KB
v25-0005-Doc-changes-describing-details-about-logical-dec.patch text/plain 2.1 KB
v25-0006-Fixing-Walsender-corner-cases-with-logical-decod.patch text/plain 7.2 KB

In response to

Responses

Browse pgsql-hackers by date

  From Date Subject
Next Message Michael Paquier 2021-10-27 07:59:15 Re: [PATCH] Added TRANSFORM FOR for COMMENT tab completion
Previous Message Shinya Kato 2021-10-27 06:54:03 Re: [PATCH] Added TRANSFORM FOR for COMMENT tab completion