Re: BUG #18014: Releasing catcache entries makes schema_to_xmlschema() fail when parallel workers are used

Поиск
Список
Период
Сортировка
От Alexander Lakhin
Тема Re: BUG #18014: Releasing catcache entries makes schema_to_xmlschema() fail when parallel workers are used
Дата
Msg-id 5bd4cbfe-fc71-c576-851d-3bb21ef5c080@gmail.com
обсуждение исходный текст
Ответ на Re: BUG #18014: Releasing catcache entries makes schema_to_xmlschema() fail when parallel workers are used  (Tom Lane <tgl@sss.pgh.pa.us>)
Ответы Re: BUG #18014: Releasing catcache entries makes schema_to_xmlschema() fail when parallel workers are used  (Kyotaro Horiguchi <horikyota.ntt@gmail.com>)
Список pgsql-bugs
Hi Tom,

21.07.2023 22:21, Tom Lane wrote:
> Yes, we certainly want to do that during LockRelationOid.  But what
> seems to be happening here is an inval while we are closing/unlocking
> the catalog we got the syscache entry from.  That is, the expected
> behavior here is:
>
> SearchSysCacheExists:
>
>    * is entry present-and-valid?
>      No, so...
>
>    * open and lock relevant catalog (with possible inval)
>
>    * scan catalog, find desired row, create valid syscache entry
>
>    * close and unlock catalog
>
>    * return success
>
> SearchSysCache1 (from pg_class_aclmask_ext):
>
>    * is entry present-and-valid?
>      Yes, so increment its refcount and return it
>
> There is no inval in the entry-already-present code path in syscache
> lookup.  So if we are seeing this failure, ISTM it must mean that an
> inval is happening during "close and unlock catalog", which seems like
> something that we don't want.  But I've not traced exactly how that
> happens.

Yes, but here we deal with -DCATCACHE_FORCE_RELEASE (added to config_env
on prion), so the cache entry, that was just found in
SearchSysCacheExists(), is removed immediately because of
SearchSysCacheExists() ->  ReleaseSysCache(tuple) -> ReleaseCatCache(tuple).

So, while the construction "if (SearchSysCacheExists()) ... SearchSysCache1()"
seems robust for normal conditions, it might be broken when catcache entries
released forcefully. Thus, if the worst consequence of the issue is sporadic
test failures on prion, then may be fix it in a least invasive way (on level 1).

Best regards,
Alexander



В списке pgsql-bugs по дате отправления:

Предыдущее
От: Черников Д А
Дата:
Сообщение: Add instructions for downloading Linux (Mint)
Следующее
От: David Rowley
Дата:
Сообщение: Re: BUG #18035: Assertion failure in jsonb_path_query