Re: BUG #18246: pgstathashindex() attempts to read invalid file for hash index attached to partitioned table
В списке pgsql-bugs по дате отправления:
| От | Alexander Lakhin |
|---|---|
| Тема | Re: BUG #18246: pgstathashindex() attempts to read invalid file for hash index attached to partitioned table |
| Дата | |
| Msg-id | 11c0916f-82de-decf-c27a-c01a4f8dfcef@gmail.com обсуждение исходный текст |
| Ответ на | Re: BUG #18246: pgstathashindex() attempts to read invalid file for hash index attached to partitioned table (Alexander Lakhin <exclusion@gmail.com>) |
| Ответы |
Re: BUG #18246: pgstathashindex() attempts to read invalid file for hash index attached to partitioned table
|
| Список | pgsql-bugs |
13.12.2023 21:00, Alexander Lakhin wrote:
> Hello Michael,
>
> 13.12.2023 17:18, Michael Paquier wrote:
>> On Wed, Dec 13, 2023 at 09:00:01AM +0000, PG Bug reporting form wrote:
>>> This anomaly can be observed since 8b08f7d48 from 2018-01-19, but IMO the
>>> culprit is e759854a0 from 2017-02-03, which introduced the following
>>> asymmetry in pgstatindex.c:
>>> if (!IS_INDEX(rel) || !IS_BTREE(rel))
>>> if (!IS_INDEX(rel) || !IS_GIN(rel))
>>> But:
>>> if (!IS_HASH(rel))
>> Fun, let's fix that. Would you like to write a patch?
>
> Yes, please look at the attached,
Looking around, I found the similar index_open() usage within pageinspect,
function hash_bitmap_info():
CREATE EXTENSION pageinspect;
CREATE TABLE t (a int, b int[], c int) PARTITION BY RANGE (a);
CREATE INDEX c_idx ON t USING hash(c);
SELECT hash_bitmap_info('c_idx'::regclass, 1);
Leads to:
TRAP: failed Assert("false"), File: "bufmgr.c", Line: 3606, PID: 3984550
I'm inclined to leave index_open() there for the internal consistency
inside pageinspect, and to use the same condition as in
bt_index_block_validate(), which called by functions bt_page_stats(...),
bt_multi_page_stats(...), bt_page_items(relname text, blkno bigint).
Functions for other index types, brin/gin/gist, don't read the index,
instead they receive a page as input.
Please look at the additional patch.
Best regards,
Alexander
В списке pgsql-bugs по дате отправления:
Сайт использует файлы cookie для корректной работы и повышения удобства. Нажимая кнопку «Принять» или продолжая пользоваться сайтом, вы соглашаетесь на их использование в соответствии с Политикой в отношении обработки cookie ООО «ППГ», в том числе на передачу данных из файлов cookie сторонним статистическим и рекламным службам. Вы можете управлять настройками cookie через параметры вашего браузера