From 5018c0b380474ede4bf957ac3b1e393e278ec38a Mon Sep 17 00:00:00 2001 From: Viraj Jasani Date: Thu, 10 Sep 2020 21:22:37 +0530 Subject: [PATCH] HBASE-25004 : Log RegionTooBusyException details (#2371) Signed-off-by: mnpoonia Signed-off-by: stack --- .../hadoop/hbase/regionserver/HRegion.java | 31 ++++++++++++------- 1 file changed, 20 insertions(+), 11 deletions(-) diff --git a/hbase-server/src/main/java/org/apache/hadoop/hbase/regionserver/HRegion.java b/hbase-server/src/main/java/org/apache/hadoop/hbase/regionserver/HRegion.java index a934e5d07c3..9babc65f88e 100644 --- a/hbase-server/src/main/java/org/apache/hadoop/hbase/regionserver/HRegion.java +++ b/hbase-server/src/main/java/org/apache/hadoop/hbase/regionserver/HRegion.java @@ -4971,12 +4971,17 @@ public class HRegion implements HeapSize, PropagatingConfigurationObserver, Regi requestFlush(); // Don't print current limit because it will vary too much. The message is used as a key // over in RetriesExhaustedWithDetailsException processing. - throw new RegionTooBusyException("Over memstore limit=" + - org.apache.hadoop.hbase.procedure2.util.StringUtils.humanSize(this.blockingMemStoreSize) + - ", regionName=" + - (this.getRegionInfo() == null? "unknown": this.getRegionInfo().getEncodedName()) + - ", server=" + (this.getRegionServerServices() == null? "unknown": - this.getRegionServerServices().getServerName())); + final String regionName = + this.getRegionInfo() == null ? "unknown" : this.getRegionInfo().getEncodedName(); + final String serverName = this.getRegionServerServices() == null ? + "unknown" : (this.getRegionServerServices().getServerName() == null ? "unknown" : + this.getRegionServerServices().getServerName().toString()); + 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)) { // Don't print millis. Message is used as a key over in // RetriesExhaustedWithDetailsException processing. - throw new RegionTooBusyException("Failed to obtain lock; regionName=" + - (this.getRegionInfo() == null? "unknown": - this.getRegionInfo().getRegionNameAsString()) + - ", server=" + (this.getRegionServerServices() == null? "unknown": - this.getRegionServerServices().getServerName())); + final String regionName = + this.getRegionInfo() == null ? "unknown" : this.getRegionInfo().getRegionNameAsString(); + final String serverName = this.getRegionServerServices() == null ? + "unknown" : (this.getRegionServerServices().getServerName() == null ? + "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) { LOG.info("Interrupted while waiting for a lock in region {}", this);