[PATCH] BUG FIX: inconsistent page found in BRIN_REGULAR_PAGE

Поиск
Список
Период
Сортировка
От Karina Litskevich
Тема [PATCH] BUG FIX: inconsistent page found in BRIN_REGULAR_PAGE
Дата
Msg-id a5559c95-52c3-5eea-cd63-9b4f1c70ff96@gmail.com
обсуждение исходный текст
Ответ на Re: [External] Re: [PATCH] BUG FIX: inconsistent page found in BRIN_REGULAR_PAGE  (Alvaro Herrera <alvherre@alvh.no-ip.org>)
Ответы Re: [PATCH] BUG FIX: inconsistent page found in BRIN_REGULAR_PAGE
Список pgsql-bugs
Hi Alvaro!

Is there any special reason to read WAL records until the last inserted 
record?

+my $end_lsn = $whiskey->lsn('insert');
+
+my ($ret, $out, $err) = $whiskey->psql(
+    'postgres', qq{
+    select count(*) from pg_get_wal_records_info('$start_lsn', '$end_lsn')
+    where resource_manager = 'BRIN' AND
+    record_type ILIKE '%revmap%'
+    });
+cmp_ok($out, '>=', 1);

It seems that in some rare situations on slower machines this test can 
fail. If
any background process inserts a WAL record before lsn('insert') and 
this record
isn't flushed before pg_get_wal_records_info('$start_lsn', '$end_lsn'),
pg_get_wal_records_info('$start_lsn', '$end_lsn') ends with ERROR 
"cannot accept
future end LSN" as it works only if record with end LSN is inserted.

I attached two patches with two ways of fixing this minor issue.

Best regards,
Karina Litskevich
Postgres Professional: http://postgrespro.com/

Вложения

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

Предыдущее
От: Tom Lane
Дата:
Сообщение: Re: BUG #17728: When jdbc calls the stored procedure, portal->stmts in FillPortalStore is null, causing a processing
Следующее
От: Alvaro Herrera
Дата:
Сообщение: Re: [PATCH] BUG FIX: inconsistent page found in BRIN_REGULAR_PAGE