Re: Checkpoint not retrying failed fsync?

Поиск
Список
Период
Сортировка
От Thomas Munro
Тема Re: Checkpoint not retrying failed fsync?
Дата
Msg-id CAEepm=1bVBFXsWkM5w74z6DdM3rdbTYhsVk6P+9fgZwVoyp=Fg@mail.gmail.com
обсуждение исходный текст
Ответ на Re: Checkpoint not retrying failed fsync?  (Thomas Munro <thomas.munro@enterprisedb.com>)
Ответы Re: Checkpoint not retrying failed fsync?  (Thomas Munro <thomas.munro@enterprisedb.com>)
Re: Checkpoint not retrying failed fsync?  (Amit Kapila <amit.kapila16@gmail.com>)
Список pgsql-hackers
On Fri, Apr 6, 2018 at 11:36 AM, Thomas Munro
<thomas.munro@enterprisedb.com> wrote:
> On Fri, Apr 6, 2018 at 11:34 AM, Andrew Gierth
> <andrew@tao11.riddles.org.uk> wrote:
>> Right.
>>
>> But I don't think just copying the value is sufficient; if a new bit was
>> set while we were processing the old ones, how would we know which to
>> clear? We couldn't just clear all the bits afterwards because then we
>> might lose a request.
>
> Agreed.  The attached draft patch handles that correctly, I think.

After some testing, here is a better one for review.  Changes:

1.  The copy wasn't really needed.
2.  errno needed to be restored (in case bms_union stomped on it),
thanks to Andrew for an off-list complaint about that.
3.  Memory context was wrong.
4.  bms_first_member() eats its input.  Need to use bms_next_member() instead.
5.  Mustn't leak in error path (that was a pre-existing bug).

Also here's a patch to test it.  If the file /tmp/broken_fsync exists,
you'll see a fake EIO when you CHECKPOINT.

-- 
Thomas Munro
http://www.enterprisedb.com

Вложения

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

Предыдущее
От: Daniel Gustafsson
Дата:
Сообщение: Re: Online enabling of checksums
Следующее
От: Thomas Munro
Дата:
Сообщение: Re: Checkpoint not retrying failed fsync?