com.ksc.metrics.ServiceLatencyProvider Maven / Gradle / Ivy
The newest version!
/*
* Copyright 2010-2016 ksyun.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License").
* You may not use this file except in compliance with the License.
* A copy of the License is located at
*
* http://ksyun.com/apache2.0
*
* or in the "license" file accompanying this file. This file 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.ksc.metrics;
import org.apache.commons.logging.LogFactory;
import org.apache.http.annotation.NotThreadSafe;
import com.ksc.util.TimingInfo;
/**
* Latency metric information provider.
*/
@NotThreadSafe
public class ServiceLatencyProvider {
private final long startNano = System.nanoTime();
private long endNano = startNano;
private final ServiceMetricType serviceMetricType;
public ServiceLatencyProvider(ServiceMetricType type) {
this.serviceMetricType = type;
}
public ServiceMetricType getServiceMetricType() { return serviceMetricType; }
/**
* Ends the timing. Must not be called more than once.
*/
public ServiceLatencyProvider endTiming() {
if (endNano != startNano) {
throw new IllegalStateException();
}
endNano = System.nanoTime();
return this;
}
public double getDurationMilli() {
if (endNano == startNano) {
LogFactory.getLog(getClass()).debug(
"Likely to be a missing invocation of endTiming().");
}
return TimingInfo.durationMilliOf(startNano, endNano);
}
public String getProviderId() { return super.toString(); }
@Override
public String toString() {
return String.format(
"providerId=%s, serviceMetricType=%s, startNano=%d, endNano=%d",
getProviderId(), serviceMetricType, startNano, endNano);
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy