aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPeter Geoghegan <pg@bowt.ie>2018-08-03 14:45:02 -0700
committerPeter Geoghegan <pg@bowt.ie>2018-08-03 14:45:02 -0700
commitb9612e5cfab828e496108c8e5379fdfac625ae01 (patch)
treebf72fb4cd01c3eb4b93bd139030f0464b5e223c6
parenta3958178935a0258a1850a9f4ac710fbaaa3344f (diff)
downloadpostgresql-b9612e5cfab828e496108c8e5379fdfac625ae01.tar.gz
postgresql-b9612e5cfab828e496108c8e5379fdfac625ae01.zip
Add table relcache invalidation to index builds.
It's necessary to make sure that owning tables have a relcache invalidation prior to advancing the command counter to make newly-entered catalog tuples for the index visible. inval.c must be able to maintain the consistency of the local caches in the event of transaction abort. There is usually only a problem when CREATE INDEX transactions abort, since there is a generic invalidation once we reach index_update_stats(). This bug is of long standing. Problems were made much more likely by the addition of parallel CREATE INDEX (commit 9da0cc35284), but it is strongly suspected that similar problems can be triggered without involving plan_create_index_workers(). (plan_create_index_workers() triggers a relcache build or rebuild, which previously only happened in rare edge cases.) Author: Peter Geoghegan Reported-By: Luca Ferrari Diagnosed-By: Andres Freund Reviewed-By: Andres Freund Discussion: https://postgr.es/m/CAKoxK+5fVodiCtMsXKV_1YAKXbzwSfp7DgDqUmcUAzeAhf=HEQ@mail.gmail.com Backpatch: 9.3-
-rw-r--r--src/backend/catalog/index.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/src/backend/catalog/index.c b/src/backend/catalog/index.c
index 8b276bc430f..2dad7b059e9 100644
--- a/src/backend/catalog/index.c
+++ b/src/backend/catalog/index.c
@@ -978,6 +978,12 @@ index_create(Relation heapRelation,
!concurrent && !invalid,
!concurrent);
+ /*
+ * Register relcache invalidation on the indexes' heap relation, to
+ * maintain consistency of its index list
+ */
+ CacheInvalidateRelcache(heapRelation);
+
/* update pg_inherits, if needed */
if (OidIsValid(parentIndexRelid))
StoreSingleInheritance(indexRelationId, parentIndexRelid, 1);