Re: Proposal for CSN based snapshots

Поиск
Список
Период
Сортировка
От Heikki Linnakangas
Тема Re: Proposal for CSN based snapshots
Дата
Msg-id 79213506-4c9c-7e7a-44c6-ae94484c1159@iki.fi
обсуждение исходный текст
Ответ на Re: Proposal for CSN based snapshots  (Tom Lane <tgl@sss.pgh.pa.us>)
Ответы Re: Proposal for CSN based snapshots  (Tom Lane <tgl@sss.pgh.pa.us>)
Список pgsql-hackers
On 08/10/2016 05:09 PM, Tom Lane wrote:
> Heikki Linnakangas <hlinnaka@iki.fi> writes:
>> Imagine that you have a stream of normal, synchronous, commits. They get
>> assigned LSNs: 1, 2, 3, 4. They become visible to other transactions in
>> that order.
>
>> The way I described this scheme in the first emails on this thread, was
>> to use the current WAL insertion position as the snapshot. That's not
>> correct, though: you have to use the current WAL *flush* position as the
>> snapshot. Otherwise you would see the results of a transaction that
>> hasn't been flushed to disk yet, i.e. which might still get lost, if you
>> pull the power plug before the flush happens. So you have to use the
>> last flush position as the snapshot.
>
> Uh, what?  That's not the semantics we have today, and I don't see why
> it's necessary or a good idea.  Once the commit is in the WAL stream,
> any action taken on the basis of seeing the commit must be later in
> the WAL stream.  So what's the problem?

I was talking about synchronous commits in the above. A synchronous 
commit is not made visible to other transactions, until the commit WAL 
record is flushed to disk.

You could argue that that doesn't need to be so, because indeed any 
action taken on the basis of seeing the commit must be later in the WAL 
stream. But that's what asynchronous commits are for. For synchronous 
commits, we have a higher standard.

- Heikki




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

Предыдущее
От: Bruce Momjian
Дата:
Сообщение: Re: Wait events monitoring future development
Следующее
От: Satoshi Nagayasu
Дата:
Сообщение: Re: Wait events monitoring future development