From 944551228e4c2b4ec015359821122d9676fcf7e0 Mon Sep 17 00:00:00 2001 From: Andrey Borodin Date: Mon, 11 May 2020 16:17:02 +0500 Subject: [PATCH v1 3/3] Make MultiXact local cache size configurable --- doc/src/sgml/config.sgml | 16 ++++++++++++++++ src/backend/access/transam/multixact.c | 2 +- src/backend/utils/init/globals.c | 1 + src/backend/utils/misc/guc.c | 10 ++++++++++ src/include/miscadmin.h | 1 + 5 files changed, 29 insertions(+), 1 deletion(-) diff --git a/doc/src/sgml/config.sgml b/doc/src/sgml/config.sgml index 71aa5c4900..6dbc3ce5f1 100644 --- a/doc/src/sgml/config.sgml +++ b/doc/src/sgml/config.sgml @@ -1777,6 +1777,22 @@ include_dir 'conf.d' + + multixact_local_cache_entries (integer) + + multixact_local_cache_entries configuration parameter + + + + + Specifies the number cached MultiXact by backend. Any SLRU lookup is preceeded + by cache lookup. Higher numbers of cache size help to deduplicate lock sets, while + lower values make cache lookup faster. + It defaults to 256. + + + + max_stack_depth (integer) diff --git a/src/backend/access/transam/multixact.c b/src/backend/access/transam/multixact.c index 5387a3602d..62f9bf73eb 100644 --- a/src/backend/access/transam/multixact.c +++ b/src/backend/access/transam/multixact.c @@ -1589,7 +1589,7 @@ mXactCachePut(MultiXactId multi, int nmembers, MultiXactMember *members) qsort(entry->members, nmembers, sizeof(MultiXactMember), mxactMemberComparator); dlist_push_head(&MXactCache, &entry->node); - if (MXactCacheMembers++ >= MAX_CACHE_ENTRIES) + if (MXactCacheMembers++ >= multixact_local_cache_entries) { dlist_node *node; mXactCacheEnt *entry; diff --git a/src/backend/utils/init/globals.c b/src/backend/utils/init/globals.c index aebfbdb67c..b17382293c 100644 --- a/src/backend/utils/init/globals.c +++ b/src/backend/utils/init/globals.c @@ -151,3 +151,4 @@ double vacuum_cleanup_index_scale_factor; int multixact_offsets_slru_buffers = 8; int multixact_members_slru_buffers = 16; +int multixact_local_cache_entries = 256; diff --git a/src/backend/utils/misc/guc.c b/src/backend/utils/misc/guc.c index b139e387f3..a74f8a8f20 100644 --- a/src/backend/utils/misc/guc.c +++ b/src/backend/utils/misc/guc.c @@ -2292,6 +2292,16 @@ static struct config_int ConfigureNamesInt[] = NULL, NULL, NULL }, + { + {"multixact_local_cache_entries", PGC_SUSET, RESOURCES_MEM, + gettext_noop("Sets the number cached MultiXact by backend."), + NULL + }, + &multixact_local_cache_entries, + 256, 2, INT_MAX / 2, + NULL, NULL, NULL + }, + { {"temp_buffers", PGC_USERSET, RESOURCES_MEM, gettext_noop("Sets the maximum number of temporary buffers used by each session."), diff --git a/src/include/miscadmin.h b/src/include/miscadmin.h index 95f4633a88..27d5170ff1 100644 --- a/src/include/miscadmin.h +++ b/src/include/miscadmin.h @@ -163,6 +163,7 @@ extern PGDLLIMPORT int max_worker_processes; extern PGDLLIMPORT int max_parallel_workers; extern PGDLLIMPORT int multixact_offsets_slru_buffers; extern PGDLLIMPORT int multixact_members_slru_buffers; +extern PGDLLIMPORT int multixact_local_cache_entries; extern PGDLLIMPORT int MyProcPid; extern PGDLLIMPORT pg_time_t MyStartTime; -- 2.24.2 (Apple Git-127)