All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.hadoop.fs.statistics.DurationStatisticSummary Maven / Gradle / Ivy

The newest version!
/*
 * 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.hadoop.fs.statistics;

import javax.annotation.Nullable;
import java.io.Serializable;

import org.apache.hadoop.classification.InterfaceAudience;
import org.apache.hadoop.classification.InterfaceStability;

import static org.apache.hadoop.fs.statistics.StoreStatisticNames.SUFFIX_FAILURES;
import static org.apache.hadoop.fs.statistics.StoreStatisticNames.SUFFIX_MAX;
import static org.apache.hadoop.fs.statistics.StoreStatisticNames.SUFFIX_MEAN;
import static org.apache.hadoop.fs.statistics.StoreStatisticNames.SUFFIX_MIN;

/**
 * Summary of duration tracking statistics
 * as extracted from an IOStatistics instance.
 * 

* This is for reporting and testing. */ @InterfaceAudience.Public @InterfaceStability.Unstable public final class DurationStatisticSummary implements Serializable { private static final long serialVersionUID = 6776381340896518486L; /** Statistic key. */ private final String key; /** Are these success or failure statistics. */ private final boolean success; /** Count of operation invocations. */ private final long count; /** Max duration; -1 if unknown. */ private final long max; /** Min duration; -1 if unknown. */ private final long min; /** Mean duration -may be null. */ private final MeanStatistic mean; /** * Constructor. * @param key Statistic key. * @param success Are these success or failure statistics. * @param count Count of operation invocations. * @param max Max duration; -1 if unknown. * @param min Min duration; -1 if unknown. * @param mean Mean duration -may be null. (will be cloned) */ public DurationStatisticSummary(final String key, final boolean success, final long count, final long max, final long min, @Nullable final MeanStatistic mean) { this.key = key; this.success = success; this.count = count; this.max = max; this.min = min; this.mean = mean == null ? null : mean.clone(); } public String getKey() { return key; } public boolean isSuccess() { return success; } public long getCount() { return count; } public long getMax() { return max; } public long getMin() { return min; } public MeanStatistic getMean() { return mean; } @Override public String toString() { return "DurationStatisticSummary{" + "key='" + key + '\'' + ", success=" + success + ", counter=" + count + ", max=" + max + ", mean=" + mean + '}'; } /** * Fetch the duration timing summary of success or failure operations * from an IO Statistics source. * If the duration key is unknown, the summary will be incomplete. * @param source source of data * @param key duration statistic key * @param success fetch success statistics, or if false, failure stats. * @return a summary of the statistics. */ public static DurationStatisticSummary fetchDurationSummary( IOStatistics source, String key, boolean success) { String fullkey = success ? key : key + SUFFIX_FAILURES; return new DurationStatisticSummary(key, success, source.counters().getOrDefault(fullkey, 0L), source.maximums().getOrDefault(fullkey + SUFFIX_MAX, -1L), source.minimums().getOrDefault(fullkey + SUFFIX_MIN, -1L), source.meanStatistics() .get(fullkey + SUFFIX_MEAN)); } /** * Fetch the duration timing summary from an IOStatistics source. * If the duration key is unknown, the summary will be incomplete. * @param source source of data * @param key duration statistic key * @return a summary of the statistics. */ public static DurationStatisticSummary fetchSuccessSummary( IOStatistics source, String key) { return fetchDurationSummary(source, key, true); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy