是否可以使用 MBean 记录 jvm GC 活动、cpu 使用情况或其他 jvm 信息?如果是这样,如何?
问问题
314 次
1 回答
1
ClassLoadingMXBean clMxBean = ManagementFactory.getClassLoadingMXBean();
System.out.println("loadedClassCount:" + clMxBean.getLoadedClassCount());
System.out.println("totalLoadedClassCount:" + clMxBean.getTotalLoadedClassCount());
System.out.println("unloadedClassCount:" + clMxBean.getUnloadedClassCount());
List<GarbageCollectorMXBean> gcMxBeans = ManagementFactory.getGarbageCollectorMXBeans();
for(GarbageCollectorMXBean gcMxBean : gcMxBeans)
{
System.out.println("\ngcMxBean: " + gcMxBean.getName() +
", collection count:" + gcMxBean.getCollectionCount() +
", Collection time:" + gcMxBean.getCollectionTime() +
", Memory Pool Names:" + Arrays.deepToString(gcMxBean.getMemoryPoolNames()) );
}
OperatingSystemMXBean osMxBean = ManagementFactory.getOperatingSystemMXBean();
double systemLoadAverageInLast1Minute = osMxBean.getSystemLoadAverage();
int availableProcessors = osMxBean.getAvailableProcessors();
System.out.println("\nlast 1 minute load average over all CPUs: " + systemLoadAverageInLast1Minute);
System.out.println("last 1 minute load average per CPU: " + (systemLoadAverageInLast1Minute/availableProcessors) );
于 2012-06-07T06:29:49.923 回答