]> granicus.if.org Git - postgresql/commit
Fix serialization anomalies due to race conditions on INSERT.
authorKevin Grittner <kgrittn@postgresql.org>
Sat, 31 Oct 2015 19:36:58 +0000 (14:36 -0500)
committerKevin Grittner <kgrittn@postgresql.org>
Sat, 31 Oct 2015 19:36:58 +0000 (14:36 -0500)
commit08322daed33e0c35b77194c4ad70dbd21790c7e6
tree0ef7332e02eea3e959edd6d0fef4513338d47731
parentb97a41a7c0270be436b800a83abfffc18a5427a5
Fix serialization anomalies due to race conditions on INSERT.

On insert the CheckForSerializableConflictIn() test was performed
before the page(s) which were going to be modified had been locked
(with an exclusive buffer content lock).  If another process
acquired a relation SIReadLock on the heap and scanned to a page on
which an insert was going to occur before the page was so locked,
a rw-conflict would be missed, which could allow a serialization
anomaly to be missed.  The window between the check and the page
lock was small, so the bug was generally not noticed unless there
was high concurrency with multiple processes inserting into the
same table.

This was reported by Peter Bailis as bug #11732, by Sean Chittenden
as bug #13667, and by others.

The race condition was eliminated in heap_insert() by moving the
check down below the acquisition of the buffer lock, which had been
the very next statement.  Because of the loop locking and unlocking
multiple buffers in heap_multi_insert() a check was added after all
inserts were completed.  The check before the start of the inserts
was left because it might avoid a large amount of work to detect a
serialization anomaly before performing the all of the inserts and
the related WAL logging.

While investigating this bug, other SSI bugs which were even harder
to hit in practice were noticed and fixed, an unnecessary check
(covered by another check, so redundant) was removed from
heap_update(), and comments were improved.

Back-patch to all supported branches.

Kevin Grittner and Thomas Munro
src/backend/access/heap/heapam.c
src/backend/storage/lmgr/predicate.c