blob: cfaf7687b6cbae2b4773e564d2f0d1bc09d9b02c [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2017 Boeing.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* Boeing - initial API and implementation
*******************************************************************************/
package org.eclipse.osee.activity.internal;
import java.lang.management.ManagementFactory;
import java.lang.management.ThreadInfo;
import java.lang.management.ThreadMXBean;
import java.util.Arrays;
/**
* @author Ryan D. Brooks
*/
public class ThreadActivity {
private final ThreadMXBean threadMxBean = ManagementFactory.getThreadMXBean();
private static final double ConvertToMillSec = 1000000.0;
private class ThreadStats {
final ThreadInfo threadInfo;
long cpuTime;
long cpuTimeElapsed;
public ThreadStats(ThreadInfo threadInfo, long cpuTime) {
this.threadInfo = threadInfo;
this.cpuTime = cpuTime;
}
public void setCpuTimeElapsed() {
cpuTimeElapsed = threadMxBean.getThreadCpuTime(threadInfo.getThreadId()) - cpuTime;
}
}
public String getThreadActivity(int sampleWindowMs) {
ThreadInfo[] threadInfos = threadMxBean.dumpAllThreads(false, false);
ThreadStats[] threadStats = new ThreadStats[threadInfos.length];
for (int i = 0; i < threadStats.length; i++) {
threadStats[i] = new ThreadStats(threadInfos[i], threadMxBean.getThreadCpuTime(threadInfos[i].getThreadId()));
}
StringBuilder sb = new StringBuilder(400);
try {
Thread.sleep(sampleWindowMs);
} catch (InterruptedException ex) {
sb.append(ex);
}
for (ThreadStats stat : threadStats) {
stat.setCpuTimeElapsed();
}
Arrays.sort(threadStats, (ThreadStats t1, ThreadStats t2) -> Long.compare(t1.cpuTimeElapsed, t2.cpuTimeElapsed));
int n = Math.max(threadStats.length - 15, 0);
for (int i = threadStats.length - 1; i >= n; i--) {
if (threadStats[i].cpuTimeElapsed == 0) {
break;
}
sb.append("[");
sb.append(threadStats[i].threadInfo.getThreadName());
sb.append("](");
sb.append(threadStats[i].cpuTimeElapsed / ConvertToMillSec);
sb.append(", ");
sb.append(threadStats[i].cpuTime / ConvertToMillSec);
sb.append(", ");
sb.append(threadStats[i].threadInfo.getBlockedTime());
StackTraceElement[] stackTrace = threadStats[i].threadInfo.getStackTrace();
if (stackTrace.length > 0) {
sb.append(", ");
sb.append(stackTrace[0]);
}
sb.append(") ");
}
return sb.toString();
}
}