• Peter Geoghegan's avatar
    Add table relcache invalidation to index builds. · b3f919da
    Peter Geoghegan authored
    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 9da0cc35), 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-
    b3f919da
index.c 131 KB