mirror of
https://github.com/postgres/postgres.git
synced 2026-01-26 09:41:40 +03:00
Fix unexpected reversal of lists during catcache rehash
During catcache searches, the most-recently searched entries are kept at the head of the list to speed up subsequent searches, keeping the "freshest" entries at its beginning. A rehash of the catcache was doing the opposite: fresh entries were moved to the tail of the newly-created buckets, causing a rehash to slow down a bit. When a rehash is done, this commit switches the code to use dlist_push_tail() instead of dlist_push_head(), so as fresh entries are kept at the head of the lists, not their tail. Author: ChangAo Chen <cca5507@qq.com> Reviewed-by: John Naylor <johncnaylorls@gmail.com> Reviewed-by: Michael Paquier <michael@paquier.xyz> Discussion: https://postgr.es/m/tencent_9EA10D8512B5FE29E7323F780A0749768708@qq.com
This commit is contained in:
18
src/backend/utils/cache/catcache.c
vendored
18
src/backend/utils/cache/catcache.c
vendored
@@ -1013,7 +1013,14 @@ RehashCatCache(CatCache *cp)
|
||||
int hashIndex = HASH_INDEX(ct->hash_value, newnbuckets);
|
||||
|
||||
dlist_delete(iter.cur);
|
||||
dlist_push_head(&newbucket[hashIndex], &ct->cache_elem);
|
||||
|
||||
/*
|
||||
* Note that each item is pushed at the tail of the new bucket,
|
||||
* not its head. This is consistent with the SearchCatCache*()
|
||||
* routines, where matching entries are moved at the front of the
|
||||
* list to speed subsequent searches.
|
||||
*/
|
||||
dlist_push_tail(&newbucket[hashIndex], &ct->cache_elem);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1051,7 +1058,14 @@ RehashCatCacheLists(CatCache *cp)
|
||||
int hashIndex = HASH_INDEX(cl->hash_value, newnbuckets);
|
||||
|
||||
dlist_delete(iter.cur);
|
||||
dlist_push_head(&newbucket[hashIndex], &cl->cache_elem);
|
||||
|
||||
/*
|
||||
* Note that each item is pushed at the tail of the new bucket,
|
||||
* not its head. This is consistent with the SearchCatCache*()
|
||||
* routines, where matching entries are moved at the front of the
|
||||
* list to speed subsequent searches.
|
||||
*/
|
||||
dlist_push_tail(&newbucket[hashIndex], &cl->cache_elem);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user