HBASE-25004 : Log RegionTooBusyException details (#2371)

Signed-off-by: mnpoonia <apoonia@salesforce.com>
Signed-off-by: stack <stack@apache.org>
This commit is contained in:
Viraj Jasani 2020-09-10 21:22:37 +05:30
parent 4b815d77d5
commit 5018c0b380
No known key found for this signature in database
GPG Key ID: B3D6C0B41C8ADFD5
1 changed files with 20 additions and 11 deletions

View File

@ -4971,12 +4971,17 @@ public class HRegion implements HeapSize, PropagatingConfigurationObserver, Regi
requestFlush(); requestFlush();
// Don't print current limit because it will vary too much. The message is used as a key // Don't print current limit because it will vary too much. The message is used as a key
// over in RetriesExhaustedWithDetailsException processing. // over in RetriesExhaustedWithDetailsException processing.
throw new RegionTooBusyException("Over memstore limit=" + final String regionName =
org.apache.hadoop.hbase.procedure2.util.StringUtils.humanSize(this.blockingMemStoreSize) + this.getRegionInfo() == null ? "unknown" : this.getRegionInfo().getEncodedName();
", regionName=" + final String serverName = this.getRegionServerServices() == null ?
(this.getRegionInfo() == null? "unknown": this.getRegionInfo().getEncodedName()) + "unknown" : (this.getRegionServerServices().getServerName() == null ? "unknown" :
", server=" + (this.getRegionServerServices() == null? "unknown": this.getRegionServerServices().getServerName().toString());
this.getRegionServerServices().getServerName())); RegionTooBusyException rtbe = new RegionTooBusyException(
"Over memstore limit=" + org.apache.hadoop.hbase.procedure2.util.StringUtils
.humanSize(this.blockingMemStoreSize) + ", regionName=" + regionName + ", server="
+ serverName);
LOG.warn("Region is too busy due to exceeding memstore size limit.", rtbe);
throw rtbe;
} }
} }
@ -8823,11 +8828,15 @@ public class HRegion implements HeapSize, PropagatingConfigurationObserver, Regi
if (!lock.tryLock(waitTime, TimeUnit.MILLISECONDS)) { if (!lock.tryLock(waitTime, TimeUnit.MILLISECONDS)) {
// Don't print millis. Message is used as a key over in // Don't print millis. Message is used as a key over in
// RetriesExhaustedWithDetailsException processing. // RetriesExhaustedWithDetailsException processing.
throw new RegionTooBusyException("Failed to obtain lock; regionName=" + final String regionName =
(this.getRegionInfo() == null? "unknown": this.getRegionInfo() == null ? "unknown" : this.getRegionInfo().getRegionNameAsString();
this.getRegionInfo().getRegionNameAsString()) + final String serverName = this.getRegionServerServices() == null ?
", server=" + (this.getRegionServerServices() == null? "unknown": "unknown" : (this.getRegionServerServices().getServerName() == null ?
this.getRegionServerServices().getServerName())); "unknown" : this.getRegionServerServices().getServerName().toString());
RegionTooBusyException rtbe = new RegionTooBusyException(
"Failed to obtain lock; regionName=" + regionName + ", server=" + serverName);
LOG.warn("Region is too busy to allow lock acquisition.", rtbe);
throw rtbe;
} }
} catch (InterruptedException ie) { } catch (InterruptedException ie) {
LOG.info("Interrupted while waiting for a lock in region {}", this); LOG.info("Interrupted while waiting for a lock in region {}", this);