Details
-
Bug
-
Status: Closed
-
Critical
-
Resolution: Fixed
-
0.23.4, 2.0.2-alpha
-
None
-
Reviewed
Description
As pointed out in HDFS-4183, when the lease monitor calls internalReleaseLease(), it acquires the namespace write lock. Inside internalReleaseLease(), if a block recovery is needed, the lease is reassigned to the namenode itself and this is logged & synced in logReassignLease().
Since this is done while the write lock is held, log syncing is blocked. When a large number of leases are expired and blocks are recovered, namenode can slow down.