From d0b820b7bc681c4fabaed98bd9fad19074717fcd Mon Sep 17 00:00:00 2001 From: Fredrik Strand Oseberg Date: Fri, 3 Nov 2023 14:33:19 +0100 Subject: [PATCH] fix: last seen deadlocks (#5264) (#5266) Patch unleash last seen at logic --- .../last-seen/last-seen-store.ts | 32 +++++++++++++------ 1 file changed, 22 insertions(+), 10 deletions(-) diff --git a/src/lib/services/client-metrics/last-seen/last-seen-store.ts b/src/lib/services/client-metrics/last-seen/last-seen-store.ts index 9dbd4059cc1e..cc1deb69303b 100644 --- a/src/lib/services/client-metrics/last-seen/last-seen-store.ts +++ b/src/lib/services/client-metrics/last-seen/last-seen-store.ts @@ -14,6 +14,26 @@ export interface FeaturesTable { environment: string; } +const prepareLastSeenInput = (data: LastSeenInput[]) => { + const now = new Date(); + + const sortedData = data.sort( + (a, b) => + a.featureName.localeCompare(b.featureName) || + a.environment.localeCompare(b.environment), + ); + + const inserts = sortedData.map((item) => { + return { + feature_name: item.featureName, + environment: item.environment, + last_seen_at: now, + }; + }); + + return inserts; +}; + export default class LastSeenStore implements ILastSeenStore { private db: Db; @@ -32,18 +52,10 @@ export default class LastSeenStore implements ILastSeenStore { } async setLastSeen(data: LastSeenInput[]): Promise { - const now = new Date(); - try { - const inserts = data.map((item) => { - return { - feature_name: item.featureName, - environment: item.environment, - last_seen_at: now, - }; - }); + const inserts = prepareLastSeenInput(data); - const batchSize = 1000; + const batchSize = 500; for (let i = 0; i < inserts.length; i += batchSize) { const batch = inserts.slice(i, i + batchSize);