blob: f6ee602ab9ce379895661a193657c541e9ed0c47 [file] [log] [blame]
/**
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with this
* work for additional information regarding copyright ownership. The ASF
* licenses this file to you 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 org.apache.bookkeeper.stats;
import com.codahale.metrics.Snapshot;
import com.codahale.metrics.Timer;
import java.util.Arrays;
import java.util.concurrent.TimeUnit;
@Deprecated
class CodahaleOpStatsLogger implements OpStatsLogger {
final Timer success;
final Timer fail;
CodahaleOpStatsLogger(Timer success, Timer fail) {
this.success = success;
this.fail = fail;
}
// OpStatsLogger functions
@Override
public void registerFailedEvent(long eventLatency, TimeUnit unit) {
fail.update(eventLatency, unit);
}
@Override
public void registerSuccessfulEvent(long eventLatency, TimeUnit unit) {
success.update(eventLatency, unit);
}
@Override
public void registerSuccessfulValue(long value) {
// Values are inserted as millis, which is the unit they will be presented, to maintain 1:1 scale
success.update(value, TimeUnit.MILLISECONDS);
}
@Override
public void registerFailedValue(long value) {
// Values are inserted as millis, which is the unit they will be presented, to maintain 1:1 scale
fail.update(value, TimeUnit.MILLISECONDS);
}
@Override
public synchronized void clear() {
// can't clear a timer
}
/**
* This function should go away soon (hopefully).
*/
@Override
public synchronized OpStatsData toOpStatsData() {
long numFailed = fail.getCount();
long numSuccess = success.getCount();
Snapshot s = success.getSnapshot();
double avgLatencyMillis = s.getMean();
double[] defaultPercentiles = {10, 50, 90, 99, 99.9, 99.99};
long[] latenciesMillis = new long[defaultPercentiles.length];
Arrays.fill(latenciesMillis, Long.MAX_VALUE);
for (int i = 0; i < defaultPercentiles.length; i++) {
latenciesMillis[i] = (long) s.getValue(defaultPercentiles[i] / 100);
}
return new OpStatsData(numSuccess, numFailed, avgLatencyMillis, latenciesMillis);
}
}