Re: Remove HeapTuple and Buffer dependency for predicate locking functions
От | Thomas Munro |
---|---|
Тема | Re: Remove HeapTuple and Buffer dependency for predicate locking functions |
Дата | |
Msg-id | CA+hUKGLOizZpVx=X_tik+ZaTOKsAyWrTaeSYUngMqQaz-ZEw8A@mail.gmail.com обсуждение исходный текст |
Ответ на | Re: Remove HeapTuple and Buffer dependency for predicate locking functions (Ashwin Agrawal <aagrawal@pivotal.io>) |
Ответы |
Re: Remove HeapTuple and Buffer dependency for predicate lockingfunctions
|
Список | pgsql-hackers |
On Sat, Aug 3, 2019 at 11:56 AM Ashwin Agrawal <aagrawal@pivotal.io> wrote: > On Wed, Jul 31, 2019 at 2:06 PM Andres Freund <andres@anarazel.de> wrote: >> I'm also a bit confused why we don't need to pass in the offset of the >> current tuple, rather than the HOT root tuple here. That's not related >> to this patch. But aren't we locking the wrong tuple here, in case of >> HOT? > > Yes, root is being locked here instead of the HOT. But I don't have full context on the same. If we wish to fix it though,can be easily done now with the patch by passing "tid" instead of &(heapTuple->t_self). Here are three relevant commits: 1. Commit dafaa3efb75 "Implement genuine serializable isolation level." (2011) locked the root tuple, because it set t_self to *tid. Possibly due to confusion about the effect of the preceding line ItemPointerSetOffsetNumber(tid, offnum). 2. Commit commit 81fbbfe3352 "Fix bugs in SSI tuple locking." (2013) fixed that by adding ItemPointerSetOffsetNumber(&heapTuple->t_self, offnum). 3. Commit b89e151054a "Introduce logical decoding." (2014) also did ItemPointerSet(&(heapTuple->t_self), BufferGetBlockNumber(buffer), offnum), for the benefit of historical MVCC snapshots (unnecessarily, considering the change in the commit #2), but then, intending to "reset to original, non-redirected, tid", clobbered it, reintroducing the bug fixed by #2. My first guess is that commit #3 above was developed before commit #2, and finished up clobbering it. In fact, both logical decoding and SSI want offnum, so we should be able to just remove the "reset" bit (perhaps like in the attached sketch, not really tested, though it passes). This must be in want of an isolation test, but I haven't yet tried to get my head around how to write a test that would show the difference. -- Thomas Munro https://enterprisedb.com
Вложения
В списке pgsql-hackers по дате отправления: