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:
parent
4b815d77d5
commit
5018c0b380
|
@ -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);
|
||||||
|
|
Loading…
Reference in New Issue