]> granicus.if.org Git - postgresql/commit
Do some restructuring to improve performance of the catcaches. Teach
authorTom Lane <tgl@sss.pgh.pa.us>
Mon, 18 Jun 2001 03:35:07 +0000 (03:35 +0000)
committerTom Lane <tgl@sss.pgh.pa.us>
Mon, 18 Jun 2001 03:35:07 +0000 (03:35 +0000)
commit2c5aa2acb49d3aad560429295e3998e7aa7d7e7a
tree1f30a6323ec6b30478e0b44ac02ae442adeb500e
parent41c377f5c6689fa95949fd7abd2d3a0d600d1be0
Do some restructuring to improve performance of the catcaches.  Teach
CatalogCacheFlushRelation (formerly called SystemCacheRelationFlushed)
how to distinguish tuples it should flush from those it needn't; this
means a relcache flush event now only removes the catcache entries
it ought to, rather than zapping the caches completely as it used to.
Testing with the regression tests indicates that this considerably
improves the lifespan of catcache entries.  Also, rearrange catcache
data structures so that the limit on number of cached tuples applies
globally across all the catcaches, rather than being per-catcache.
It was a little silly to have the same size limit on both, say,
pg_attribute caches and pg_am caches (there being only four possible
rows in the latter...).  Doing LRU removal across all the caches
instead of locally in each one should reduce cache reload traffic
in the more heavily used caches and improve the efficiency of
cache memory use.
src/backend/utils/cache/catcache.c
src/backend/utils/cache/inval.c
src/backend/utils/cache/relcache.c
src/backend/utils/cache/syscache.c
src/include/utils/catcache.h