HBASE-14778 Make block cache hit percentages not integer in the metrics system
This commit is contained in:
parent
1a6ec1bac6
commit
ea795213b2
|
@ -151,12 +151,12 @@ public interface MetricsRegionServerWrapper {
|
||||||
/**
|
/**
|
||||||
* Get the percent of HFiles' that are local.
|
* Get the percent of HFiles' that are local.
|
||||||
*/
|
*/
|
||||||
int getPercentFileLocal();
|
double getPercentFileLocal();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the percent of HFiles' that are local for secondary region replicas.
|
* Get the percent of HFiles' that are local for secondary region replicas.
|
||||||
*/
|
*/
|
||||||
int getPercentFileLocalSecondaryRegions();
|
double getPercentFileLocalSecondaryRegions();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the size of the split queue
|
* Get the size of the split queue
|
||||||
|
@ -231,7 +231,7 @@ public interface MetricsRegionServerWrapper {
|
||||||
/**
|
/**
|
||||||
* Get the percent of requests with the block cache turned on that hit the block cache.
|
* Get the percent of requests with the block cache turned on that hit the block cache.
|
||||||
*/
|
*/
|
||||||
int getBlockCacheHitCachingPercent();
|
double getBlockCacheHitCachingPercent();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Force a re-computation of the metrics.
|
* Force a re-computation of the metrics.
|
||||||
|
@ -341,20 +341,20 @@ public interface MetricsRegionServerWrapper {
|
||||||
/**
|
/**
|
||||||
* Gets the hit percent to the mob file cache.
|
* Gets the hit percent to the mob file cache.
|
||||||
*/
|
*/
|
||||||
int getMobFileCacheHitPercent();
|
double getMobFileCacheHitPercent();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return Count of hedged read operations
|
* @return Count of hedged read operations
|
||||||
*/
|
*/
|
||||||
public long getHedgedReadOps();
|
long getHedgedReadOps();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return Count of times a hedged read beat out the primary read.
|
* @return Count of times a hedged read beat out the primary read.
|
||||||
*/
|
*/
|
||||||
public long getHedgedReadWins();
|
long getHedgedReadWins();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return Count of requests blocked because the memstore size is larger than blockingMemStoreSize
|
* @return Count of requests blocked because the memstore size is larger than blockingMemStoreSize
|
||||||
*/
|
*/
|
||||||
public long getBlockedRequestsCount();
|
long getBlockedRequestsCount();
|
||||||
}
|
}
|
||||||
|
|
|
@ -74,8 +74,8 @@ class MetricsRegionServerWrapperImpl
|
||||||
private volatile long totalStaticBloomSize = 0;
|
private volatile long totalStaticBloomSize = 0;
|
||||||
private volatile long numMutationsWithoutWAL = 0;
|
private volatile long numMutationsWithoutWAL = 0;
|
||||||
private volatile long dataInMemoryWithoutWAL = 0;
|
private volatile long dataInMemoryWithoutWAL = 0;
|
||||||
private volatile int percentFileLocal = 0;
|
private volatile double percentFileLocal = 0;
|
||||||
private volatile int percentFileLocalSecondaryRegions = 0;
|
private volatile double percentFileLocalSecondaryRegions = 0;
|
||||||
private volatile long flushedCellsCount = 0;
|
private volatile long flushedCellsCount = 0;
|
||||||
private volatile long compactedCellsCount = 0;
|
private volatile long compactedCellsCount = 0;
|
||||||
private volatile long majorCompactedCellsCount = 0;
|
private volatile long majorCompactedCellsCount = 0;
|
||||||
|
@ -330,15 +330,25 @@ class MetricsRegionServerWrapperImpl
|
||||||
if (this.cacheStats == null) {
|
if (this.cacheStats == null) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
return (int) (this.cacheStats.getHitRatio() * 100);
|
double ratio = this.cacheStats.getHitRatio();
|
||||||
|
if (Double.isNaN(ratio)) {
|
||||||
|
ratio = 0;
|
||||||
|
}
|
||||||
|
return (ratio * 100);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getBlockCacheHitCachingPercent() {
|
public double getBlockCacheHitCachingPercent() {
|
||||||
if (this.cacheStats == null) {
|
if (this.cacheStats == null) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
return (int) (this.cacheStats.getHitCachingRatio() * 100);
|
|
||||||
|
double ratio = this.cacheStats.getHitCachingRatio();
|
||||||
|
|
||||||
|
if (Double.isNaN(ratio)) {
|
||||||
|
ratio = 0;
|
||||||
|
}
|
||||||
|
return (ratio * 100);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override public void forceRecompute() {
|
@Override public void forceRecompute() {
|
||||||
|
@ -425,12 +435,12 @@ class MetricsRegionServerWrapperImpl
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getPercentFileLocal() {
|
public double getPercentFileLocal() {
|
||||||
return percentFileLocal;
|
return percentFileLocal;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getPercentFileLocalSecondaryRegions() {
|
public double getPercentFileLocalSecondaryRegions() {
|
||||||
return percentFileLocalSecondaryRegions;
|
return percentFileLocalSecondaryRegions;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -538,8 +548,8 @@ class MetricsRegionServerWrapperImpl
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getMobFileCacheHitPercent() {
|
public double getMobFileCacheHitPercent() {
|
||||||
return (int) (mobFileCacheHitRatio * 100);
|
return mobFileCacheHitRatio * 100;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -572,8 +582,8 @@ class MetricsRegionServerWrapperImpl
|
||||||
long tempTotalStaticBloomSize = 0;
|
long tempTotalStaticBloomSize = 0;
|
||||||
long tempNumMutationsWithoutWAL = 0;
|
long tempNumMutationsWithoutWAL = 0;
|
||||||
long tempDataInMemoryWithoutWAL = 0;
|
long tempDataInMemoryWithoutWAL = 0;
|
||||||
int tempPercentFileLocal = 0;
|
double tempPercentFileLocal = 0;
|
||||||
int tempPercentFileLocalSecondaryRegions = 0;
|
double tempPercentFileLocalSecondaryRegions = 0;
|
||||||
long tempFlushedCellsCount = 0;
|
long tempFlushedCellsCount = 0;
|
||||||
long tempCompactedCellsCount = 0;
|
long tempCompactedCellsCount = 0;
|
||||||
long tempMajorCompactedCellsCount = 0;
|
long tempMajorCompactedCellsCount = 0;
|
||||||
|
@ -589,7 +599,7 @@ class MetricsRegionServerWrapperImpl
|
||||||
long tempMobFlushedCellsSize = 0;
|
long tempMobFlushedCellsSize = 0;
|
||||||
long tempMobScanCellsCount = 0;
|
long tempMobScanCellsCount = 0;
|
||||||
long tempMobScanCellsSize = 0;
|
long tempMobScanCellsSize = 0;
|
||||||
long tempBlockedRequestsCount = 0L;
|
long tempBlockedRequestsCount = 0;
|
||||||
|
|
||||||
for (Region r : regionServer.getOnlineRegionsLocalContext()) {
|
for (Region r : regionServer.getOnlineRegionsLocalContext()) {
|
||||||
tempNumMutationsWithoutWAL += r.getNumMutationsWithoutWAL();
|
tempNumMutationsWithoutWAL += r.getNumMutationsWithoutWAL();
|
||||||
|
@ -636,13 +646,14 @@ class MetricsRegionServerWrapperImpl
|
||||||
}
|
}
|
||||||
float localityIndex = hdfsBlocksDistribution.getBlockLocalityIndex(
|
float localityIndex = hdfsBlocksDistribution.getBlockLocalityIndex(
|
||||||
regionServer.getServerName().getHostname());
|
regionServer.getServerName().getHostname());
|
||||||
tempPercentFileLocal = (int) (localityIndex * 100);
|
tempPercentFileLocal = Double.isNaN(tempBlockedRequestsCount) ? 0 : (localityIndex * 100);
|
||||||
|
|
||||||
float localityIndexSecondaryRegions = hdfsBlocksDistributionSecondaryRegions
|
float localityIndexSecondaryRegions = hdfsBlocksDistributionSecondaryRegions
|
||||||
.getBlockLocalityIndex(regionServer.getServerName().getHostname());
|
.getBlockLocalityIndex(regionServer.getServerName().getHostname());
|
||||||
tempPercentFileLocalSecondaryRegions = (int) (localityIndexSecondaryRegions * 100);
|
tempPercentFileLocalSecondaryRegions =
|
||||||
|
Double.isNaN(localityIndexSecondaryRegions) ? 0 : (localityIndexSecondaryRegions * 100);
|
||||||
|
|
||||||
//Compute the number of requests per second
|
// Compute the number of requests per second
|
||||||
long currentTime = EnvironmentEdgeManager.currentTime();
|
long currentTime = EnvironmentEdgeManager.currentTime();
|
||||||
|
|
||||||
// assume that it took PERIOD seconds to start the executor.
|
// assume that it took PERIOD seconds to start the executor.
|
||||||
|
@ -650,7 +661,7 @@ class MetricsRegionServerWrapperImpl
|
||||||
if (lastRan == 0) {
|
if (lastRan == 0) {
|
||||||
lastRan = currentTime - period;
|
lastRan = currentTime - period;
|
||||||
}
|
}
|
||||||
//If we've time traveled keep the last requests per second.
|
// If we've time traveled keep the last requests per second.
|
||||||
if ((currentTime - lastRan) > 0) {
|
if ((currentTime - lastRan) > 0) {
|
||||||
long currentRequestCount = getTotalRequestCount();
|
long currentRequestCount = getTotalRequestCount();
|
||||||
requestsPerSecond = (currentRequestCount - lastRequestCount) /
|
requestsPerSecond = (currentRequestCount - lastRequestCount) /
|
||||||
|
@ -665,7 +676,7 @@ class MetricsRegionServerWrapperImpl
|
||||||
(metaProvider == null ? 0 : metaProvider.getNumLogFiles());
|
(metaProvider == null ? 0 : metaProvider.getNumLogFiles());
|
||||||
walFileSize = (provider == null ? 0 : provider.getLogFileSize()) +
|
walFileSize = (provider == null ? 0 : provider.getLogFileSize()) +
|
||||||
(provider == null ? 0 : provider.getLogFileSize());
|
(provider == null ? 0 : provider.getLogFileSize());
|
||||||
//Copy over computed values so that no thread sees half computed values.
|
// Copy over computed values so that no thread sees half computed values.
|
||||||
numStores = tempNumStores;
|
numStores = tempNumStores;
|
||||||
numStoreFiles = tempNumStoreFiles;
|
numStoreFiles = tempNumStoreFiles;
|
||||||
memstoreSize = tempMemstoreSize;
|
memstoreSize = tempMemstoreSize;
|
||||||
|
@ -698,7 +709,7 @@ class MetricsRegionServerWrapperImpl
|
||||||
mobScanCellsSize = tempMobScanCellsSize;
|
mobScanCellsSize = tempMobScanCellsSize;
|
||||||
mobFileCacheAccessCount = mobFileCache.getAccessCount();
|
mobFileCacheAccessCount = mobFileCache.getAccessCount();
|
||||||
mobFileCacheMissCount = mobFileCache.getMissCount();
|
mobFileCacheMissCount = mobFileCache.getMissCount();
|
||||||
mobFileCacheHitRatio = mobFileCache.getHitRatio();
|
mobFileCacheHitRatio = Double.isNaN(mobFileCache.getHitRatio())?0:mobFileCache.getHitRatio();
|
||||||
mobFileCacheEvictedCount = mobFileCache.getEvictedFileCount();
|
mobFileCacheEvictedCount = mobFileCache.getEvictedFileCount();
|
||||||
mobFileCacheCount = mobFileCache.getCacheSize();
|
mobFileCacheCount = mobFileCache.getCacheSize();
|
||||||
blockedRequestsCount = tempBlockedRequestsCount;
|
blockedRequestsCount = tempBlockedRequestsCount;
|
||||||
|
|
|
@ -126,12 +126,12 @@ public class MetricsRegionServerWrapperStub implements MetricsRegionServerWrappe
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getPercentFileLocal() {
|
public double getPercentFileLocal() {
|
||||||
return 99;
|
return 99;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getPercentFileLocalSecondaryRegions() {
|
public double getPercentFileLocalSecondaryRegions() {
|
||||||
return 99;
|
return 99;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -206,7 +206,7 @@ public class MetricsRegionServerWrapperStub implements MetricsRegionServerWrappe
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getBlockCacheHitCachingPercent() {
|
public double getBlockCacheHitCachingPercent() {
|
||||||
return 97;
|
return 97;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -347,7 +347,7 @@ public class MetricsRegionServerWrapperStub implements MetricsRegionServerWrappe
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getMobFileCacheHitPercent() {
|
public double getMobFileCacheHitPercent() {
|
||||||
return 50;
|
return 50;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue