![JAR search and dependency download from the Maven repository](/logo.png)
io.pcp.parfait.TimeWindow Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of parfait-core Show documentation
Show all versions of parfait-core Show documentation
Java performance monitoring framework, including PCP bridge
The newest version!
/*
* Copyright 2009-2017 Aconex
*
* 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 io.pcp.parfait;
import net.jcip.annotations.ThreadSafe;
import com.google.common.base.Preconditions;
/**
* A 'time bucket', used for counters which represent an event count or metric
* delta over a limited, sliding time window. For example, the number of
* requests served or bytes written in the last 60 seconds. Takes both a period
* (the amount of time represented by each window), and a resolution (the
* duration at which events will be clustered together).
*/
@ThreadSafe
public final class TimeWindow {
private final int resolution;
private final long period;
private final String name;
private TimeWindow(int resolution, long period, String name) {
Preconditions.checkArgument(resolution > 0,
"resolution must be positive");
Preconditions.checkArgument(period > 0L,
"period covered must be positive");
Preconditions.checkArgument(period % resolution == 0,
"period covered %s must be divisible by resolution %s", period,
resolution);
Preconditions.checkArgument(period / resolution < Integer.MAX_VALUE,
"cannot have more than Integer.MAX_VALUE windows");
this.resolution = resolution;
this.period = period;
this.name = Preconditions.checkNotNull(name);
}
public String getName() {
return name;
}
public int getResolution() {
return resolution;
}
public long getPeriod() {
return period;
}
/**
* Factory method to create a new TimeWindow.
*
* @param resolution
* the fine-grained resolution at which individual events will be
* aggregated. Must be a positive factor of period
* @param period
* the duration represented (at least at a
* resolution
resolution-level accuracy)
* @param name
* a short name for the window; used to name
* automatically-generated metrics based on this window. e.g.
* '1m' or '12h'.
*/
public static TimeWindow of(int resolution, long period, String name) {
return new TimeWindow(resolution, period, name);
}
public int getBuckets() {
// We know that bucket count fits in an int, per our constructor checks
return (int) (period / resolution);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy