org.kie.perf.metrics.ThreadStatesGaugeSet Maven / Gradle / Ivy
package org.kie.perf.metrics;
import static com.codahale.metrics.MetricRegistry.name;
import java.lang.management.ManagementFactory;
import java.lang.management.ThreadInfo;
import java.lang.management.ThreadMXBean;
import java.util.Collections;
import java.util.HashMap;
import java.util.Map;
import java.util.Set;
import com.codahale.metrics.Gauge;
import com.codahale.metrics.Metric;
import com.codahale.metrics.MetricRegistry;
import com.codahale.metrics.MetricSet;
import com.codahale.metrics.jvm.ThreadDeadlockDetector;
public class ThreadStatesGaugeSet implements MetricSet {
// do not compute stack traces.
private static final int STACK_TRACE_DEPTH = 0;
private Class> scenario;
private final ThreadMXBean threads;
private final ThreadDeadlockDetector deadlockDetector;
public ThreadStatesGaugeSet(Class> scenario) {
this.scenario = scenario;
this.threads = ManagementFactory.getThreadMXBean();
this.deadlockDetector = new ThreadDeadlockDetector();
}
@Override
public Map getMetrics() {
final Map gauges = new HashMap();
for (final Thread.State state : Thread.State.values()) {
gauges.put(MetricRegistry.name(scenario, "thread.state", state.toString().toLowerCase(), "count"), new Gauge