Re: BUG #16162: create index using gist_trgm_ops leads to panic

Поиск
Список
Период
Сортировка
От Heikki Linnakangas
Тема Re: BUG #16162: create index using gist_trgm_ops leads to panic
Дата
Msg-id 2ca3ae2a-e770-012b-3da1-169a3818927a@iki.fi
обсуждение исходный текст
Ответ на Re: BUG #16162: create index using gist_trgm_ops leads to panic  (Tomas Vondra <tomas.vondra@2ndquadrant.com>)
Ответы Re: BUG #16162: create index using gist_trgm_ops leads to panic  (Jeff Janes <jeff.janes@gmail.com>)
Re: BUG #16162: create index using gist_trgm_ops leads to panic  (Alexander Lakhin <exclusion@gmail.com>)
Список pgsql-bugs
On 13/12/2019 02:16, Tomas Vondra wrote:
 > On Thu, Dec 12, 2019 at 07:05:53PM -0500, Jeff Janes wrote:
 >> On Thu, Dec 12, 2019 at 8:44 AM Tom Lane <tgl@sss.pgh.pa.us> wrote:
 >>> I wonder if this could be a recently-introduced bug?  I do not
 >>> recall seeing complaints like this before v12.
 >>
 >> Looks like the culprit is:
 >>
 >> commit 9155580fd5fc2a0cbb23376dfca7cd21f59c2c7b
 >> Author: Heikki Linnakangas <heikki.linnakangas@iki.fi>
 >> Date:   Wed Apr 3 17:03:15 2019 +0300
 >>
 >>     Generate less WAL during GiST, GIN and SP-GiST index build.
 >>
 >> The commit before went 150 iterations with no failures, while this one
 >> failed on the 15th iteration, then again on 4th.
 >
 > Thanks for the bisect. I've planned to try reproducing this on 11, but
 > this commit only in 12, so Tom is right it's a recent bug.

Like Tom suspected at [1], the bug was that the parent page got split, 
and the stacked information wasn't updated. The code called 
gistFindCorrectParent(), which should've updated the stack, but that 
function checked the LSN of the page and did nothing if it matched. To 
trigger the bug, you needed to have an insertion that split a page into 
three (or more) pages, and inserting the downlink caused the parent page 
to split, too.

Committed a fix. Many thanks for the reproducer scripts, Andreas and 
Alexander!

[1] https://www.postgresql.org/message-id/9409.1574617130%40sss.pgh.pa.us

- Heikki



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

Предыдущее
От: Heikki Linnakangas
Дата:
Сообщение: Re: BUG #16162: create index using gist_trgm_ops leads to panic
Следующее
От: Jeremy Schneider
Дата:
Сообщение: Re: logical decoding bug: segfault in ReorderBufferToastReplace()