Details
-
Improvement
-
Status: Resolved
-
Major
-
Resolution: Abandoned
-
None
-
None
-
None
-
None
Description
The disk with 12TB capacity is very normal today, which means the FBR size is much larger than before, BlockManager holds the NameSystemLock during processing block report for each storage, which might take quite a long time.
On our production environment, processing large FBR usually cause a longer RPC queue time, which impacts client latency, so we did some simple work on refining the lock usage, which improved the p99 latency significantly.
In our solution, BlockManager release the NameSystem write lock and request it again for every 5000 blocks(by default) during processing FBR, with the fair lock, all the RPC request can be processed before BlockManager re-acquire the write lock.
Attachments
Issue Links
- duplicates
-
HDFS-14657 Refine NameSystem lock usage during processing FBR
- Patch Available