Re: The XLogFindNextRecord() routine find incorrect record startpoint after a long continuation record

Поиск
Список
Период
Сортировка
От Andrey Lepikhov
Тема Re: The XLogFindNextRecord() routine find incorrect record startpoint after a long continuation record
Дата
Msg-id c57afeaf-4cf5-84a9-d19b-738f3f801e78@postgrespro.ru
обсуждение исходный текст
Ответ на Re: The XLogFindNextRecord() routine find incorrect record startpoint after a long continuation record  (Michael Paquier <michael@paquier.xyz>)
Ответы ***UNCHECKED*** Re: The XLogFindNextRecord() routine find incorrectrecord start point after a long continuation record  (Fujii Masao <masao.fujii@gmail.com>)
Список pgsql-bugs

On 06/11/2019 09:41, Michael Paquier wrote:
> On Wed, Nov 06, 2019 at 07:40:48AM +0500, Andrey Lepikhov wrote:
>> I found this in our multimaster project on PostgreSQL 11.5. It is difficult
>> to reproduce this error, but I will try to do it if necessary.
>>
>> The rest of a continuation WAL-record can exactly match the block size. In
>> this case, we need to switch targetPagePtr to the next block before
>> calculating the starting point of the next WAL-record.
>> See the patch in attachment for the bug fix.
> 
> What's the error you actually saw after reading the record in
> xlogreader.c?  If you have past WAL archives, perhaps you are able to
> reproduce the problem with a given WAL segment and pg_waldump?

I saw the message:
pg_waldump: xlogreader.c:264: XLogReadRecord: <Text in russian> 
"((RecPtr) % 8192 >= (((uintptr_t) ((sizeof(XLogPageHeaderData))) + ((8) 
- 1)) & ~((uintptr_t) ((8) - 1))))" <Text in russian>

Yes, I reproduced error with pg_waldump too. The patch in previous 
letter fixed this problem.

some details:
I have the record:
rmgr: Transaction len (rec/tot): 86/ 86, tx: 0, lsn: 0/11FFFF98, prev 
0/11FFFDA8, desc: COMMIT_PREPARED

The next record occupied the rest of segment No.11 and 8151 bytes of the 
first block of the segment No.12, i.e. its size is 8167 bytes.

Problematic record (I got it by pg_waldump after applying the patch) is:
rmgr: Heap len (rec/tot): 71/ 8167, tx: 1249835485258, lsn: 0/11FFFFF0, 
prev 0/11FFFF98, desc: LOCK off 8: xid 1249835485258: flags 0 LOCK_ONLY 
EXCL_LOCK KEYS_UPDATED , blkref #0: rel 1663/13121/16474 blk 10880 FPW

-- 
Andrey Lepikhov
Postgres Professional
https://postgrespro.com
The Russian Postgres Company



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

Предыдущее
От: Michael Paquier
Дата:
Сообщение: Re: The XLogFindNextRecord() routine find incorrect record startpoint after a long continuation record
Следующее
От: "Skjalg A. Skagen"
Дата:
Сообщение: Re: PostgreSQL 12 installation fails because locale name contained non-english characters