package stormpot.examples;
import com.codahale.metrics.Histogram;
import com.codahale.metrics.MetricRegistry;
import stormpot.MetricsRecorder;
public class CodaHaleMetricsRecorder implements MetricsRecorder {
private final Histogram allocationLatency;
private final Histogram allocationFailureLatency;
private final Histogram deallocationLatency;
private final Histogram reallocationLatency;
private final Histogram reallocationFailureLatency;
private final Histogram objectLifetime;
public CodaHaleMetricsRecorder(String baseName, MetricRegistry registry) {
allocationLatency = registry.histogram(baseName + ".allocationLatency");
allocationFailureLatency = registry.histogram(baseName + ".allocationFailureLatency");
deallocationLatency = registry.histogram(baseName + ".deallocationLatency");
reallocationLatency = registry.histogram(baseName + ".reallocationLatency");
reallocationFailureLatency = registry.histogram(baseName + ".reallocationFailureLatency");
objectLifetime = registry.histogram(baseName + ".objectLifetime");
}
@Override
public void recordAllocationLatencySampleMillis(long milliseconds) {
allocationLatency.update(milliseconds);
}
@Override
public void recordAllocationFailureLatencySampleMillis(long milliseconds) {
allocationFailureLatency.update(milliseconds);
}
@Override
public void recordDeallocationLatencySampleMillis(long milliseconds) {
deallocationLatency.update(milliseconds);
}
@Override
public void recordReallocationLatencySampleMillis(long milliseconds) {
reallocationLatency.update(milliseconds);
}
@Override
public void recordReallocationFailureLatencySampleMillis(long milliseconds) {
reallocationFailureLatency.update(milliseconds);
}
@Override
public void recordObjectLifetimeSampleMillis(long milliseconds) {
objectLifetime.update(milliseconds);
}
@Override
public double getAllocationLatencyPercentile(double percentile) {
return allocationLatency.getSnapshot().getValue(percentile);
}
@Override
public double getAllocationFailureLatencyPercentile(double percentile) {
return allocationFailureLatency.getSnapshot().getValue(percentile);
}
@Override
public double getDeallocationLatencyPercentile(double percentile) {
return deallocationLatency.getSnapshot().getValue(percentile);
}
@Override
public double getReallocationLatencyPercentile(double percentile) {
return reallocationLatency.getSnapshot().getValue(percentile);
}
@Override
public double getReallocationFailurePercentile(double percentile) {
return reallocationFailureLatency.getSnapshot().getValue(percentile);
}
@Override
public double getObjectLifetimePercentile(double percentile) {
return objectLifetime.getSnapshot().getValue(percentile);
}
}