]> granicus.if.org Git - postgresql/commit
Reduce page locking in GIN vacuum
authorTeodor Sigaev <teodor@sigaev.ru>
Thu, 23 Mar 2017 16:38:47 +0000 (19:38 +0300)
committerTeodor Sigaev <teodor@sigaev.ru>
Thu, 23 Mar 2017 16:38:47 +0000 (19:38 +0300)
commit218f51584d5a9fcdf702bcc7f54b5b65e255c187
tree6aa7f521be1a389a5cb8de72c58246f2c927e9d4
parent73561013e5aa44a1669b2cb4351f5e2b29485efb
Reduce page locking in GIN vacuum

GIN vacuum during cleaning posting tree can lock this whole tree for a long
time with by holding LockBufferForCleanup() on root. Patch changes it with
two ways: first, cleanup lock will be taken only if there is an empty page
(which should be deleted) and, second, it tries to lock only subtree, not the
whole posting tree.

Author: Andrey Borodin with minor editorization by me
Reviewed-by: Jeff Davis, me
https://commitfest.postgresql.org/13/896/
src/backend/access/gin/README
src/backend/access/gin/ginbtree.c
src/backend/access/gin/ginvacuum.c
src/include/access/gin_private.h