diff --git a/hbase-server/src/main/java/org/apache/hadoop/hbase/io/hfile/CombinedBlockCache.java b/hbase-server/src/main/java/org/apache/hadoop/hbase/io/hfile/CombinedBlockCache.java index 92f5a47e6403..d3f2a73eb323 100644 --- a/hbase-server/src/main/java/org/apache/hadoop/hbase/io/hfile/CombinedBlockCache.java +++ b/hbase-server/src/main/java/org/apache/hadoop/hbase/io/hfile/CombinedBlockCache.java @@ -78,7 +78,13 @@ public Cacheable getBlock(BlockCacheKey cacheKey, boolean caching, // we end up calling l2Cache.getBlock. // We are not in a position to exactly look at LRU cache or BC as BlockType may not be getting // passed always. - return l1Cache.containsBlock(cacheKey)? + boolean existInL1 = l1Cache.containsBlock(cacheKey); + if (!existInL1 && updateCacheMetrics && !repeat) { + // If the block does not exist in L1, the containsBlock should be counted as one miss. + l1Cache.getStats().miss(caching, cacheKey.isPrimary(), cacheKey.getBlockType()); + } + + return existInL1 ? l1Cache.getBlock(cacheKey, caching, repeat, updateCacheMetrics): l2Cache.getBlock(cacheKey, caching, repeat, updateCacheMetrics); }