data:image/s3,"s3://crabby-images/02ace/02ace956f9868cf2a1a780bd2c0a517cd3a46077" alt="JAR search and dependency download from the Maven repository"
com.etsy.statsd.profiler.util.TimeUtil Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of statsd-jvm-profiler Show documentation
Show all versions of statsd-jvm-profiler Show documentation
Simple JVM profiler using StatsD
package com.etsy.statsd.profiler.util;
import java.util.concurrent.TimeUnit;
/**
* Utility class for working with time
*
* @author Andrew Johnson
*/
public class TimeUtil {
/**
* Convert a reporting period into the time scale of a profiling period
*
* @param profilePeriod The profiling period
* @param profileTimeUnit The TimeUnit for the profiling period
* @param reportingPeriod The reporting period
* @param reportingTimeUnit The TimeUnit for the reporting period
* @return The reporting period scaled to the profiling period (i.e. suitable for use like x % convertReportingPeriod(...) == 0)
*/
public static long convertReportingPeriod(long profilePeriod, TimeUnit profileTimeUnit, long reportingPeriod, TimeUnit reportingTimeUnit) {
long convertedReportingPeriod = profileTimeUnit.convert(reportingPeriod, reportingTimeUnit);
// If we profile less frequently than we want report, returning 1 would indicate we should always report
if (convertedReportingPeriod <= profilePeriod) {
return 1;
}
return convertedReportingPeriod / profilePeriod;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy