klippy_connection: exclude configfile attrs from subscription cache

The configfile "config" and "settings" attributes never change, and
therefore do not need to be stored in the subscription cache.  They
can be significantly large, so this change can free up some memory
on low resource systems.

Signed-off-by:  Eric Callahan <arksine.code@gmail.com>
This commit is contained in:
Eric Callahan 2024-01-25 07:51:30 -05:00
parent 4b9973826e
commit 896cd8c41e
No known key found for this signature in database
GPG Key ID: 5A1EB336DFB4C71B
1 changed files with 23 additions and 11 deletions

View File

@ -49,6 +49,12 @@ RESERVED_ENDPOINTS = [
"register_remote_method", "register_remote_method",
] ]
# Items to exclude from the subscription cache. They never change and can be
# quite large.
CACHE_EXCLUSIONS = {
"configfile": ["config", "settings"]
}
INIT_TIME = .25 INIT_TIME = .25
LOG_ATTEMPT_INTERVAL = int(2. / INIT_TIME + .5) LOG_ATTEMPT_INTERVAL = int(2. / INIT_TIME + .5)
MAX_LOG_ATTEMPTS = 10 * LOG_ATTEMPT_INTERVAL MAX_LOG_ATTEMPTS = 10 * LOG_ATTEMPT_INTERVAL
@ -586,16 +592,6 @@ class KlippyConnection:
"No connection associated with subscription request" "No connection associated with subscription request"
) )
requested_sub: Subscription = args.get('objects', {}) requested_sub: Subscription = args.get('objects', {})
if self.server.is_verbose_enabled() and "configfile" in requested_sub:
cfg_sub = requested_sub["configfile"]
if (
cfg_sub is None or "config" in cfg_sub or "settings" in cfg_sub
):
logging.debug(
f"Detected 'configfile: {cfg_sub}' subscription. The "
"'config' and 'status' fields in this object do not change "
"and substantially increase cache size."
)
all_subs: Subscription = dict(requested_sub) all_subs: Subscription = dict(requested_sub)
# Build the subscription request from a superset of all client subscriptions # Build the subscription request from a superset of all client subscriptions
for sub in self.subscriptions.values(): for sub in self.subscriptions.values():
@ -627,7 +623,23 @@ class KlippyConnection:
continue continue
if value != cached_status[field_name]: if value != cached_status[field_name]:
status_diff.setdefault(obj, {})[field_name] = value status_diff.setdefault(obj, {})[field_name] = value
self.subscription_cache[obj] = fields if obj in CACHE_EXCLUSIONS:
# Make a shallow copy so we can pop off fields we want to
# exclude from the cache without modifying the return value
fields_to_cache = dict(fields)
removed: List[str] = []
for excluded_field in CACHE_EXCLUSIONS[obj]:
if excluded_field in fields_to_cache:
removed.append(excluded_field)
del fields_to_cache[excluded_field]
if removed:
logging.debug(
"Removed excluded fields from subscription cache: "
f"{obj}: {removed}"
)
self.subscription_cache[obj] = fields_to_cache
else:
self.subscription_cache[obj] = fields
# Prune Response # Prune Response
if obj in requested_sub: if obj in requested_sub:
valid_fields = requested_sub[obj] valid_fields = requested_sub[obj]