]> granicus.if.org Git - postgresql/commit
Fix the logic for putting relations into the relcache init file.
authorTom Lane <tgl@sss.pgh.pa.us>
Thu, 25 Jun 2015 18:39:05 +0000 (14:39 -0400)
committerTom Lane <tgl@sss.pgh.pa.us>
Thu, 25 Jun 2015 18:39:05 +0000 (14:39 -0400)
commit5d1ff6bd559ea8df1b7302e245e690b01b9a4fa4
treef475beb55da01ba4be2f87b5bcf5a00865e608b8
parentd759b7eb6aee12bd52516905d790072845b4356f
Fix the logic for putting relations into the relcache init file.

Commit f3b5565dd4e59576be4c772da364704863e6a835 was a couple of bricks shy
of a load; specifically, it missed putting pg_trigger_tgrelid_tgname_index
into the relcache init file, because that index is not used by any
syscache.  However, we have historically nailed that index into cache for
performance reasons.  The upshot was that load_relcache_init_file always
decided that the init file was busted and silently ignored it, resulting
in a significant hit to backend startup speed.

To fix, reinstantiate RelationIdIsInInitFile() as a wrapper around
RelationSupportsSysCache(), which can know about additional relations
that should be in the init file despite being unknown to syscache.c.

Also install some guards against future mistakes of this type: make
write_relcache_init_file Assert that all nailed relations get written to
the init file, and make load_relcache_init_file emit a WARNING if it takes
the "wrong number of nailed relations" exit path.  Now that we remove the
init files during postmaster startup, that case should never occur in the
field, even if we are starting a minor-version update that added or removed
rels from the nailed set.  So the warning shouldn't ever be seen by end
users, but it will show up in the regression tests if somebody breaks this
logic.

Back-patch to all supported branches, like the previous commit.
src/backend/utils/cache/inval.c
src/backend/utils/cache/relcache.c
src/include/utils/relcache.h