Class SampledStat
java.lang.Object
org.apache.kafka.common.metrics.stats.SampledStat
- All Implemented Interfaces:
Measurable
,MeasurableStat
,MetricValueProvider<Double>
,Stat
- Direct Known Subclasses:
Avg
,Frequencies
,Max
,Min
,Percentiles
,WindowedSum
A SampledStat records a single scalar value measured over one or more samples. Each sample is recorded over a
configurable window. The window can be defined by number of events or elapsed time (or both, if both are given the
window is complete when either the event count or elapsed time criterion is met).
All the samples are combined to produce the measurement. When a window is complete the oldest sample is cleared and recycled to begin recording the next sample. Subclasses of this class define different statistics measured using this basic pattern.
-
Nested Class Summary
-
Field Summary
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionabstract double
combine
(List<SampledStat.Sample> samples, MetricConfig config, long now) current
(long timeMs) double
measure
(MetricConfig config, long now) Measure this quantity and return the result as a doubleprotected SampledStat.Sample
newSample
(long timeMs) oldest
(long now) protected void
purgeObsoleteSamples
(MetricConfig config, long now) void
record
(MetricConfig config, double value, long timeMs) Record the given valuetoString()
protected abstract void
update
(SampledStat.Sample sample, MetricConfig config, double value, long timeMs)
-
Field Details
-
samples
-
-
Constructor Details
-
SampledStat
public SampledStat(double initialValue)
-
-
Method Details
-
record
Description copied from interface:Stat
Record the given value -
newSample
-
measure
Description copied from interface:Measurable
Measure this quantity and return the result as a double- Specified by:
measure
in interfaceMeasurable
- Parameters:
config
- The configuration for this metricnow
- The POSIX time in milliseconds the measurement is being taken- Returns:
- The measured value
-
current
-
oldest
-
toString
-
update
protected abstract void update(SampledStat.Sample sample, MetricConfig config, double value, long timeMs) -
combine
-
purgeObsoleteSamples
-