HBASE-26190 High rate logging of BucketAllocatorException: Allocation too big - Addendum (#3792)
This commit is contained in:
parent
d23a5b5aac
commit
35264037ef
|
@ -1001,16 +1001,17 @@ public class BucketCache implements BlockCache, HeapSize {
|
||||||
*/
|
*/
|
||||||
private String getAllocationFailWarningMessage(RAMQueueEntry re) {
|
private String getAllocationFailWarningMessage(RAMQueueEntry re) {
|
||||||
if (re != null && re.getData() instanceof HFileBlock) {
|
if (re != null && re.getData() instanceof HFileBlock) {
|
||||||
HFileBlock block = (HFileBlock) re.getData();
|
HFileContext fileContext = ((HFileBlock) re.getData()).getHFileContext();
|
||||||
HFileContext fileContext = block.getHFileContext();
|
|
||||||
String hFileName = fileContext.getHFileName();
|
|
||||||
String columnFamily = Bytes.toString(fileContext.getColumnFamily());
|
String columnFamily = Bytes.toString(fileContext.getColumnFamily());
|
||||||
String tableName = Bytes.toString(fileContext.getTableName());
|
String tableName = Bytes.toString(fileContext.getTableName());
|
||||||
return ("Most recent failed allocation in " + ALLOCATION_FAIL_LOG_TIME_PERIOD
|
if (tableName != null && columnFamily != null) {
|
||||||
+ " milliseconds; Table Name = " + tableName + ", Column Family = "
|
return ("Most recent failed allocation in " + ALLOCATION_FAIL_LOG_TIME_PERIOD
|
||||||
+ columnFamily + ", HFile Name : " + hFileName);
|
+ " milliseconds; Table Name = " + tableName + ", Column Family = " + columnFamily
|
||||||
|
+ ", HFile Name : " + fileContext.getHFileName());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return ("Failed allocation for " + (re == null ? "" : re.getKey()) + "; ");
|
return ("Most recent failed allocation in " + ALLOCATION_FAIL_LOG_TIME_PERIOD
|
||||||
|
+ " milliseconds; HFile Name : " + (re == null ? "" : re.getKey()));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1053,7 +1054,7 @@ public class BucketCache implements BlockCache, HeapSize {
|
||||||
}
|
}
|
||||||
index++;
|
index++;
|
||||||
} catch (BucketAllocatorException fle) {
|
} catch (BucketAllocatorException fle) {
|
||||||
long currTs = System.currentTimeMillis(); // Current time since Epoch in milliseconds.
|
long currTs = EnvironmentEdgeManager.currentTime();
|
||||||
cacheStats.allocationFailed(); // Record the warning.
|
cacheStats.allocationFailed(); // Record the warning.
|
||||||
if (allocFailLogPrevTs == 0 || (currTs - allocFailLogPrevTs) > ALLOCATION_FAIL_LOG_TIME_PERIOD) {
|
if (allocFailLogPrevTs == 0 || (currTs - allocFailLogPrevTs) > ALLOCATION_FAIL_LOG_TIME_PERIOD) {
|
||||||
LOG.warn (getAllocationFailWarningMessage(re), fle);
|
LOG.warn (getAllocationFailWarningMessage(re), fle);
|
||||||
|
|
Loading…
Reference in New Issue