Andrew Kyle Purtell created HBASE-27867:
-------------------------------------------

             Summary: Close the L1 victim handler race
                 Key: HBASE-27867
                 URL: https://issues.apache.org/jira/browse/HBASE-27867
             Project: HBase
          Issue Type: Bug
          Components: BlockCache
    Affects Versions: 2.5.4
            Reporter: Andrew Kyle Purtell
            Assignee: Andrew Kyle Purtell
             Fix For: 2.6.0, 3.0.0-alpha-4, 2.5.5


When we evict a block from L1 and move it to L2 there is a brief window of time 
where we have removed the block from the L1 map and yet the victim handler has 
not completed execution. Some read-your-write use cases can be significantly 
impacted even though the window is small. Imagine a use case where 
PRELOAD_DATA_ON_OPEN and CACHE_DATA_ON_WRITE are both enabled to warm cache 
ahead of access and any miss can be problematic. Perhaps a particularly latency 
sensitive case with HFiles backed by S3. 

Victim handling can be made atomic with respect to the unmapping operation with 
ConcurrentHashMap#computeIfPresent. The upside is there will be no L1+L2 misses 
during the transition. The downside is if the victim handler takes a long time 
to execute -- currently they are all very fast, so only a theoretical risk -- 
then other removals or insertions in L1 can block until it completes. 



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

Reply via email to