[
https://issues.apache.org/jira/browse/OAK-12214?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
]
Rishabh Daim updated OAK-12214:
-------------------------------
Priority: Critical (was: Major)
> SegmentCache: L1 hits should notify L2 (caffeine) to keep frequency/recency
> accurate
> ------------------------------------------------------------------------------------
>
> Key: OAK-12214
> URL: https://issues.apache.org/jira/browse/OAK-12214
> Project: Jackrabbit Oak
> Issue Type: Task
> Reporter: Rishabh Daim
> Assignee: Rishabh Daim
> Priority: Critical
>
> *Segment cache (L2)*: Caffeine W-TinyLFU and Guava LRU only learn about
> accesses that go through _SegmentCache.getSegment()_. Production traffic
> often hits _SegmentId.getSegment()_ and returns the memoized segment from L1
> without touching L2. That made eviction policies act on stale
> frequency/recency while the JVM was still reading “hot” segments from L1 —
> wrong evictions, extra TAR reads, and skewed benchmarks vs reality.
> This was working for Guava, since it was using the LRU eviction policy.
> *Fix*: On every L1 hit, call _SegmentCache.recordHit(SegmentId)_, which
> performs _cache.getIfPresent(id)_ on the backing L2 so policies see real
> usage, plus existing hit accounting.
--
This message was sent by Atlassian Jira
(v8.20.10#820010)