From c66ca38d649bb1b8f16a86b0df313ef996602562 Mon Sep 17 00:00:00 2001 From: Lezek123 Date: Fri, 12 May 2023 11:36:02 +0200 Subject: [PATCH] Fix: Cache cleanup not working for objects in group `0` --- distributor-node/CHANGELOG.md | 1 + distributor-node/src/services/cache/StateCacheService.ts | 2 +- 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/distributor-node/CHANGELOG.md b/distributor-node/CHANGELOG.md index 896835ecb1..d5a67eb615 100644 --- a/distributor-node/CHANGELOG.md +++ b/distributor-node/CHANGELOG.md @@ -1,6 +1,7 @@ ### 1.2.0 - Add support for Elasticsearch authentication (`logs.elastic.auth` config section) +- **FIX:** Objects belonging to group `0` of LRU-SP cache were never fully dropped from the state because of a bug in `StateCacheService.dropById` ### 1.1.0 (Ephesus release) diff --git a/distributor-node/src/services/cache/StateCacheService.ts b/distributor-node/src/services/cache/StateCacheService.ts index 1fe2e25ef5..b0afd8e5a0 100644 --- a/distributor-node/src/services/cache/StateCacheService.ts +++ b/distributor-node/src/services/cache/StateCacheService.ts @@ -182,7 +182,7 @@ export class StateCacheService { this.dropPendingDownload(objectId) const cacheGroupNumber = this.memoryState.groupNumberByObjectId.get(objectId) this.logger.debug('Cache group by object id established', { objectId, cacheGroupNumber }) - if (cacheGroupNumber) { + if (cacheGroupNumber !== undefined) { this.memoryState.groupNumberByObjectId.delete(objectId) this.storedState.lruCacheGroups[cacheGroupNumber].delete(objectId) }