From 1ce1fa6ea4f06706326a8dee42ae2200e81107f2 Mon Sep 17 00:00:00 2001 From: Frederik Rothenberger Date: Fri, 7 Jun 2024 10:09:33 +0200 Subject: [PATCH] Limit number of retrieved event aggregations for stats and metrics (#2498) Limit aggregations processing when retrieving stats and metrics Make sure metrics and stats will never exceed cycles limit when trying to collect event aggregations. --- .../src/stats/event_stats/event_aggregations.rs | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/src/internet_identity/src/stats/event_stats/event_aggregations.rs b/src/internet_identity/src/stats/event_stats/event_aggregations.rs index 78cc1e8e39..91c316d4d5 100644 --- a/src/internet_identity/src/stats/event_stats/event_aggregations.rs +++ b/src/internet_identity/src/stats/event_stats/event_aggregations.rs @@ -82,6 +82,11 @@ fn retrieve_aggregation_internal( ii_domain: Option, s: &Storage, ) -> Vec<(String, u64)> { + // Limit the number of aggregations retrieved in one go to avoid hitting the cycles limit when + // retrieving stats or metrics. This limit is currently over-provisioned by ~10x. + // If the limit is reached, we should switch to a naturally ordered aggregation + // data structure such that we can retrieve the top-n elements directly. + const AGGREGATIONS_LIMIT: usize = 5_000; let range_start = AggregationKey { kind: aggregation.kind(), window, @@ -92,6 +97,7 @@ fn retrieve_aggregation_internal( let mut data: Vec<_> = s .event_aggregations .range((Bound::Included(range_start), range_end)) + .take(AGGREGATIONS_LIMIT) .map(|(key, weight)| (aggregation.key_label(key), weight)) .collect(); data.sort_by(|(_, weight_a), (_, weight_b)| weight_b.cmp(weight_a));