io.nosqlbench.engine.api.metrics.HistoStatsLogger Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of nb-api Show documentation
Show all versions of nb-api Show documentation
The top level API module for NoSQLBench. This module should have no internal
module dependencies other than the mvn-default module.
All modules within NoSQLBench can safely depend on this module with circular
dependencies. This module provides cross-cutting code infrastracture, such as
path utilities and ways of describing services used between modules.
It is also the transitive aggregation point for system-wide library dependencies
for logging and testing or similar needs.
/*
*
* Copyright 2016 jshook
* 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.nosqlbench.engine.api.metrics;
import org.HdrHistogram.EncodableHistogram;
import org.HdrHistogram.Histogram;
import org.apache.logging.log4j.Logger;
import org.apache.logging.log4j.LogManager;
import java.io.File;
import java.util.List;
import java.util.concurrent.CopyOnWriteArrayList;
import java.util.concurrent.TimeUnit;
import java.util.regex.Pattern;
/**
* HistoIntervalLogger runs a separate thread to snapshotAndWrite encoded histograms on a regular interval.
* It listens to the metrics registry for any new metrics that match the pattern. Any metrics
* which both match the pattern and which are {@link EncodableHistogram}s are written the configured
* logfile at the configured interval.
*/
public class HistoStatsLogger extends CapabilityHook
implements Runnable, MetricsCloseable {
private final static Logger logger = LogManager.getLogger(HistoStatsLogger.class);
private final String sessionName;
private final TimeUnit timeUnit;
// private final long intervalMillis;
private final long intervalLength;
private final File logfile;
private HistoStatsCSVWriter writer;
private final Pattern pattern;
private final List targets = new CopyOnWriteArrayList<>();
private PeriodicRunnable executor;
private long lastRunTime=0L;
public HistoStatsLogger(String sessionName, File file, Pattern pattern, long intervalLength, TimeUnit timeUnit) {
this.sessionName = sessionName;
this.logfile = file;
this.pattern = pattern;
this.intervalLength = intervalLength;
this.timeUnit = timeUnit;
startLogging();
}
public boolean matches(String metricName) {
return pattern.matcher(metricName).matches();
}
/**
* By convention, it is typical for the logging application
* to use a comment to indicate the logging application at the head
* of the log, followed by the log format version, a startLogging time,
* and a legend (in that order).
*/
public void startLogging() {
writer = new HistoStatsCSVWriter(logfile);
writer.outputComment("logging stats for session " + sessionName);
writer.outputLogFormatVersion();
long currentTimeMillis = System.currentTimeMillis();
writer.outputStartTime(currentTimeMillis);
writer.outputTimeUnit(timeUnit);
writer.setBaseTime(currentTimeMillis);
writer.outputLegend();
this.executor = new PeriodicRunnable(this.getInterval(), this);
executor.startDaemonThread();
}
public String toString() {
return "HistoLogger:" + this.pattern + ":" + this.logfile.getPath() + ":" + this.intervalLength;
}
public long getInterval() {
return intervalLength;
}
@Override
public void onCapableAdded(String name, HdrDeltaHistogramAttachment chainedHistogram) {
if (pattern.matcher(name).matches()) {
this.targets.add(new WriterTarget(name, chainedHistogram.attachHdrDeltaHistogram()));
}
}
@Override
public void onCapableRemoved(String name, HdrDeltaHistogramAttachment capable) {
this.targets.remove(new WriterTarget(name,null));
}
@Override
protected Class getCapabilityClass() {
return HdrDeltaHistogramAttachment.class;
}
@Override
public void run() {
for (WriterTarget target : this.targets) {
Histogram nextHdrHistogram = target.histoProvider.getNextHdrDeltaHistogram();
writer.writeInterval(nextHdrHistogram);
}
this.lastRunTime = System.currentTimeMillis();
}
@Override
public void closeMetrics() {
long now = System.currentTimeMillis();
if (lastRunTime+1000 {
public String name;
public HdrDeltaHistogramProvider histoProvider;
public WriterTarget(String name, HdrDeltaHistogramProvider attach) {
this.name = name;
this.histoProvider = attach;
}
@Override
public boolean equals(Object obj) {
return name.equals(((WriterTarget)obj).name);
}
@Override
public int compareTo(WriterTarget obj) {
return name.compareTo(obj.name);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy