com.expedia.www.haystack.client.metrics.Timer Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of haystack-client-metrics-api Show documentation
Show all versions of haystack-client-metrics-api Show documentation
Metrics api consumed by the haystack client library to generate performance metrics for the client integration code
/*
* Copyright 2018 Expedia, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*/
package com.expedia.www.haystack.client.metrics;
import java.util.ArrayList;
import java.util.Collection;
import java.util.concurrent.TimeUnit;
public interface Timer {
static Builder builder(String name) {
return new Builder(name);
}
/**
* Updates the statistics kept by the counter with the specified
* amount in nanoseconds.
*
* @param duration Duration of a single event being measured by this timer.
*/
default void record(long duration) {
record(duration, TimeUnit.NANOSECONDS);
}
/**
* Updates the statistics kept by the counter with the specified amount.
*
* @param duration Duration of a single event being measured by this timer.
* @param unit Time unit for the amount being recorded.
*/
void record(long duration, TimeUnit unit);
/**
* @param unit The base unit of time to scale the total to.
* @return The total time of recorded events.
*/
double totalTime(TimeUnit unit);
/**
* @return The number of events that have been called on this timer.
*/
long count();
/**
* Returns a new {@link Sample}.
*
* @return a new {@link Sample}
* @see Sample
*/
Sample start();
/**
* Maintains state on the clock's start position for a latency sample. Complete the timing
* by calling {@link Sample#stop()}.
*/
interface Sample extends AutoCloseable {
@Override
default void close() {
stop();
}
/**
* Records the duration of the operation
*
* @return The total duration of the sample in nanoseconds
*/
long stop();
}
class Builder {
private final String name;
private final Collection tags = new ArrayList<>();
private Builder(String name) {
this.name = name;
}
public Builder tags(Collection tags) {
this.tags.addAll(tags);
return this;
}
public Builder tag(Tag tag) {
tags.add(tag);
return this;
}
public Timer register(MetricsRegistry registry) {
return registry.timer(name, tags);
}
}
}