HBASE-17017 Remove the current per-region latency histogram metrics
This commit is contained in:
parent
a70f73c1e1
commit
123d26ed90
|
@ -336,6 +336,7 @@ public interface MetricsRegionServerSource extends BaseSource, JvmPauseMonitorSo
|
||||||
String MUTATE_KEY = "mutate";
|
String MUTATE_KEY = "mutate";
|
||||||
String APPEND_KEY = "append";
|
String APPEND_KEY = "append";
|
||||||
String REPLAY_KEY = "replay";
|
String REPLAY_KEY = "replay";
|
||||||
|
String SCAN_KEY = "scan";
|
||||||
String SCAN_SIZE_KEY = "scanSize";
|
String SCAN_SIZE_KEY = "scanSize";
|
||||||
String SCAN_TIME_KEY = "scanTime";
|
String SCAN_TIME_KEY = "scanTime";
|
||||||
|
|
||||||
|
|
|
@ -59,24 +59,12 @@ public interface MetricsRegionSource extends Comparable<MetricsRegionSource> {
|
||||||
*/
|
*/
|
||||||
void updateDelete();
|
void updateDelete();
|
||||||
|
|
||||||
/**
|
|
||||||
* Update count and sizes of gets.
|
|
||||||
* @param getSize size in bytes of the resulting key values for a get
|
|
||||||
*/
|
|
||||||
void updateGetSize(long getSize);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Update time of gets
|
* Update time of gets
|
||||||
* @param mills time for this get operation.
|
* @param mills time for this get operation.
|
||||||
*/
|
*/
|
||||||
void updateGet(long mills);
|
void updateGet(long mills);
|
||||||
|
|
||||||
/**
|
|
||||||
* Update the count and sizes of resultScanner.next()
|
|
||||||
* @param scanSize Size in bytes of the resulting key values for a next()
|
|
||||||
*/
|
|
||||||
void updateScanSize(long scanSize);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Update time used of resultScanner.next().
|
* Update time used of resultScanner.next().
|
||||||
* */
|
* */
|
||||||
|
|
|
@ -24,7 +24,6 @@ import org.apache.commons.logging.Log;
|
||||||
import org.apache.commons.logging.LogFactory;
|
import org.apache.commons.logging.LogFactory;
|
||||||
import org.apache.hadoop.hbase.classification.InterfaceAudience;
|
import org.apache.hadoop.hbase.classification.InterfaceAudience;
|
||||||
import org.apache.hadoop.hbase.metrics.Interns;
|
import org.apache.hadoop.hbase.metrics.Interns;
|
||||||
import org.apache.hadoop.metrics2.MetricHistogram;
|
|
||||||
import org.apache.hadoop.metrics2.MetricsRecordBuilder;
|
import org.apache.hadoop.metrics2.MetricsRecordBuilder;
|
||||||
import org.apache.hadoop.metrics2.lib.DynamicMetricsRegistry;
|
import org.apache.hadoop.metrics2.lib.DynamicMetricsRegistry;
|
||||||
import org.apache.hadoop.metrics2.lib.MutableFastCounter;
|
import org.apache.hadoop.metrics2.lib.MutableFastCounter;
|
||||||
|
@ -48,21 +47,22 @@ public class MetricsRegionSourceImpl implements MetricsRegionSource {
|
||||||
private final String regionNamePrefix;
|
private final String regionNamePrefix;
|
||||||
private final String regionPutKey;
|
private final String regionPutKey;
|
||||||
private final String regionDeleteKey;
|
private final String regionDeleteKey;
|
||||||
private final String regionGetSizeKey;
|
|
||||||
private final String regionGetKey;
|
private final String regionGetKey;
|
||||||
private final String regionIncrementKey;
|
private final String regionIncrementKey;
|
||||||
private final String regionAppendKey;
|
private final String regionAppendKey;
|
||||||
private final String regionScanSizeKey;
|
private final String regionScanKey;
|
||||||
private final String regionScanTimeKey;
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Implementation note: Do not put histograms per region. With hundreds of regions in a server
|
||||||
|
* histograms allocate too many counters. See HBASE-17016.
|
||||||
|
*/
|
||||||
private final MutableFastCounter regionPut;
|
private final MutableFastCounter regionPut;
|
||||||
private final MutableFastCounter regionDelete;
|
private final MutableFastCounter regionDelete;
|
||||||
private final MutableFastCounter regionIncrement;
|
private final MutableFastCounter regionIncrement;
|
||||||
private final MutableFastCounter regionAppend;
|
private final MutableFastCounter regionAppend;
|
||||||
private final MetricHistogram regionGetSize;
|
private final MutableFastCounter regionGet;
|
||||||
private final MetricHistogram regionGet;
|
private final MutableFastCounter regionScan;
|
||||||
private final MetricHistogram regionScanSize;
|
|
||||||
private final MetricHistogram regionScanTime;
|
|
||||||
private final int hashCode;
|
private final int hashCode;
|
||||||
|
|
||||||
public MetricsRegionSourceImpl(MetricsRegionWrapper regionWrapper,
|
public MetricsRegionSourceImpl(MetricsRegionWrapper regionWrapper,
|
||||||
|
@ -95,17 +95,11 @@ public class MetricsRegionSourceImpl implements MetricsRegionSource {
|
||||||
regionAppendKey = regionNamePrefix + MetricsRegionServerSource.APPEND_KEY + suffix;
|
regionAppendKey = regionNamePrefix + MetricsRegionServerSource.APPEND_KEY + suffix;
|
||||||
regionAppend = registry.getCounter(regionAppendKey, 0L);
|
regionAppend = registry.getCounter(regionAppendKey, 0L);
|
||||||
|
|
||||||
regionGetSizeKey = regionNamePrefix + MetricsRegionServerSource.GET_SIZE_KEY;
|
regionGetKey = regionNamePrefix + MetricsRegionServerSource.GET_KEY + suffix;
|
||||||
regionGetSize = registry.newSizeHistogram(regionGetSizeKey);
|
regionGet = registry.getCounter(regionGetKey, 0L);
|
||||||
|
|
||||||
regionGetKey = regionNamePrefix + MetricsRegionServerSource.GET_KEY;
|
regionScanKey = regionNamePrefix + MetricsRegionServerSource.SCAN_KEY + suffix;
|
||||||
regionGet = registry.newTimeHistogram(regionGetKey);
|
regionScan = registry.getCounter(regionScanKey, 0L);
|
||||||
|
|
||||||
regionScanSizeKey = regionNamePrefix + MetricsRegionServerSource.SCAN_SIZE_KEY;
|
|
||||||
regionScanSize = registry.newSizeHistogram(regionScanSizeKey);
|
|
||||||
|
|
||||||
regionScanTimeKey = regionNamePrefix + MetricsRegionServerSource.SCAN_TIME_KEY;
|
|
||||||
regionScanTime = registry.newTimeHistogram(regionScanTimeKey);
|
|
||||||
|
|
||||||
hashCode = regionWrapper.getRegionHashCode();
|
hashCode = regionWrapper.getRegionHashCode();
|
||||||
}
|
}
|
||||||
|
@ -134,14 +128,8 @@ public class MetricsRegionSourceImpl implements MetricsRegionSource {
|
||||||
registry.removeMetric(regionDeleteKey);
|
registry.removeMetric(regionDeleteKey);
|
||||||
registry.removeMetric(regionIncrementKey);
|
registry.removeMetric(regionIncrementKey);
|
||||||
registry.removeMetric(regionAppendKey);
|
registry.removeMetric(regionAppendKey);
|
||||||
registry.removeMetric(regionGetSizeKey);
|
|
||||||
registry.removeMetric(regionGetKey);
|
registry.removeMetric(regionGetKey);
|
||||||
registry.removeMetric(regionScanSizeKey);
|
registry.removeMetric(regionScanKey);
|
||||||
registry.removeMetric(regionScanTimeKey);
|
|
||||||
registry.removeHistogramMetrics(regionGetSizeKey);
|
|
||||||
registry.removeHistogramMetrics(regionGetKey);
|
|
||||||
registry.removeHistogramMetrics(regionScanSizeKey);
|
|
||||||
registry.removeHistogramMetrics(regionScanTimeKey);
|
|
||||||
|
|
||||||
regionWrapper = null;
|
regionWrapper = null;
|
||||||
}
|
}
|
||||||
|
@ -157,24 +145,14 @@ public class MetricsRegionSourceImpl implements MetricsRegionSource {
|
||||||
regionDelete.incr();
|
regionDelete.incr();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void updateGetSize(long getSize) {
|
|
||||||
regionGetSize.add(getSize);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void updateGet(long mills) {
|
public void updateGet(long mills) {
|
||||||
regionGet.add(mills);
|
regionGet.incr();
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void updateScanSize(long scanSize) {
|
|
||||||
regionScanSize.add(scanSize);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void updateScanTime(long mills) {
|
public void updateScanTime(long mills) {
|
||||||
regionScanTime.add(mills);
|
regionScan.incr();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -7085,11 +7085,6 @@ public class HRegion implements HeapSize, PropagatingConfigurationObserver, Regi
|
||||||
|
|
||||||
void metricsUpdateForGet(List<Cell> results, long before) {
|
void metricsUpdateForGet(List<Cell> results, long before) {
|
||||||
if (this.metricsRegion != null) {
|
if (this.metricsRegion != null) {
|
||||||
long totalSize = 0L;
|
|
||||||
for (Cell cell : results) {
|
|
||||||
totalSize += CellUtil.estimatedSerializedSizeOf(cell);
|
|
||||||
}
|
|
||||||
this.metricsRegion.updateGetSize(totalSize);
|
|
||||||
this.metricsRegion.updateGet(EnvironmentEdgeManager.currentTime() - before);
|
this.metricsRegion.updateGet(EnvironmentEdgeManager.currentTime() - before);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -49,18 +49,10 @@ public class MetricsRegion {
|
||||||
source.updateDelete();
|
source.updateDelete();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void updateGetSize(final long getSize) {
|
|
||||||
source.updateGetSize(getSize);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void updateGet(final long t) {
|
public void updateGet(final long t) {
|
||||||
source.updateGet(t);
|
source.updateGet(t);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void updateScanSize(final long scanSize) {
|
|
||||||
source.updateScanSize(scanSize);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void updateScanTime(final long t) {
|
public void updateScanTime(final long t) {
|
||||||
source.updateScanTime(t);
|
source.updateScanTime(t);
|
||||||
}
|
}
|
||||||
|
|
|
@ -2718,7 +2718,6 @@ public class RSRpcServices implements HBaseRPCErrorHandler,
|
||||||
region.updateReadRequestsCount(i);
|
region.updateReadRequestsCount(i);
|
||||||
long end = EnvironmentEdgeManager.currentTime();
|
long end = EnvironmentEdgeManager.currentTime();
|
||||||
long responseCellSize = context != null ? context.getResponseCellSize() : 0;
|
long responseCellSize = context != null ? context.getResponseCellSize() : 0;
|
||||||
region.getMetrics().updateScanSize(responseCellSize);
|
|
||||||
region.getMetrics().updateScanTime(end - before);
|
region.getMetrics().updateScanTime(end - before);
|
||||||
if (regionServer.metricsRegionServer != null) {
|
if (regionServer.metricsRegionServer != null) {
|
||||||
regionServer.metricsRegionServer.updateScanSize(responseCellSize);
|
regionServer.metricsRegionServer.updateScanSize(responseCellSize);
|
||||||
|
|
|
@ -157,7 +157,7 @@ public class TestRegionServerMetrics {
|
||||||
"_table_"+tableNameString +
|
"_table_"+tableNameString +
|
||||||
"_region_" + i.getEncodedName()+
|
"_region_" + i.getEncodedName()+
|
||||||
"_metric";
|
"_metric";
|
||||||
metricsHelper.assertCounter(prefix + "_getNumOps", 10, agg);
|
metricsHelper.assertCounter(prefix + "_getCount", 10, agg);
|
||||||
metricsHelper.assertCounter(prefix + "_mutateCount", 31, agg);
|
metricsHelper.assertCounter(prefix + "_mutateCount", 31, agg);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -229,8 +229,8 @@ public class TestRegionServerMetrics {
|
||||||
"_table_"+tableNameString +
|
"_table_"+tableNameString +
|
||||||
"_region_" + i.getEncodedName()+
|
"_region_" + i.getEncodedName()+
|
||||||
"_metric";
|
"_metric";
|
||||||
metricsHelper.assertCounter(prefix + "_getSizeNumOps", 10, agg);
|
metricsHelper.assertCounter(prefix + "_getCount", 10, agg);
|
||||||
metricsHelper.assertCounter(prefix + "_getNumOps", 10, agg);
|
metricsHelper.assertCounter(prefix + "_getCount", 10, agg);
|
||||||
}
|
}
|
||||||
metricsHelper.assertCounterGt("Get_num_ops", 10, serverSource);
|
metricsHelper.assertCounterGt("Get_num_ops", 10, serverSource);
|
||||||
}
|
}
|
||||||
|
@ -446,7 +446,7 @@ public class TestRegionServerMetrics {
|
||||||
"_table_"+tableNameString +
|
"_table_"+tableNameString +
|
||||||
"_region_" + i.getEncodedName()+
|
"_region_" + i.getEncodedName()+
|
||||||
"_metric";
|
"_metric";
|
||||||
metricsHelper.assertCounter(prefix + "_scanSizeNumOps", NUM_SCAN_NEXT, agg);
|
metricsHelper.assertCounter(prefix + "_scanCount", NUM_SCAN_NEXT, agg);
|
||||||
}
|
}
|
||||||
metricsHelper.assertCounterGt("ScanSize_num_ops", numScanNext, serverSource);
|
metricsHelper.assertCounterGt("ScanSize_num_ops", numScanNext, serverSource);
|
||||||
}
|
}
|
||||||
|
@ -496,7 +496,7 @@ public class TestRegionServerMetrics {
|
||||||
"_table_"+tableNameString +
|
"_table_"+tableNameString +
|
||||||
"_region_" + i.getEncodedName()+
|
"_region_" + i.getEncodedName()+
|
||||||
"_metric";
|
"_metric";
|
||||||
metricsHelper.assertCounter(prefix + "_scanTimeNumOps", NUM_SCAN_NEXT, agg);
|
metricsHelper.assertCounter(prefix + "_scanCount", NUM_SCAN_NEXT, agg);
|
||||||
}
|
}
|
||||||
metricsHelper.assertCounterGt("ScanTime_num_ops", numScanNext, serverSource);
|
metricsHelper.assertCounterGt("ScanTime_num_ops", numScanNext, serverSource);
|
||||||
}
|
}
|
||||||
|
@ -548,7 +548,7 @@ public class TestRegionServerMetrics {
|
||||||
"_table_"+tableNameString +
|
"_table_"+tableNameString +
|
||||||
"_region_" + i.getEncodedName()+
|
"_region_" + i.getEncodedName()+
|
||||||
"_metric";
|
"_metric";
|
||||||
metricsHelper.assertCounter(prefix + "_scanSizeNumOps", NUM_SCAN_NEXT, agg);
|
metricsHelper.assertCounter(prefix + "_scanCount", NUM_SCAN_NEXT, agg);
|
||||||
}
|
}
|
||||||
metricsHelper.assertCounterGt("ScanSize_num_ops", numScanNext, serverSource);
|
metricsHelper.assertCounterGt("ScanSize_num_ops", numScanNext, serverSource);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue