org.graalvm.visualvm.sampler.cpu.ThreadInfoProvider Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of org-graalvm-visualvm-sampler Show documentation
Show all versions of org-graalvm-visualvm-sampler Show documentation
This module implements a sampling CPU and memory profiler (in contrast to the Profiler which uses instrumentation).<BR><BR>
CPU profiling requires a JMX connection to the monitored application, once correctly set up you can profile both local and remote applications.<BR><BR>
Memory profiling requires Attach API, so only local applications running on JDK 6+ are supported.
/*
* Copyright (c) 2007, 2021, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation. Oracle designates this
* particular file as subject to the "Classpath" exception as provided
* by Oracle in the LICENSE file that accompanied this code.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
package org.graalvm.visualvm.sampler.cpu;
import org.graalvm.visualvm.application.Application;
import org.graalvm.visualvm.application.jvm.JvmFactory;
import org.graalvm.visualvm.core.datasupport.Stateful;
import org.graalvm.visualvm.tools.jmx.JmxModel;
import org.graalvm.visualvm.tools.jmx.JmxModelFactory;
import org.graalvm.visualvm.tools.jmx.JvmMXBeans;
import org.graalvm.visualvm.tools.jmx.JvmMXBeansFactory;
import java.lang.management.ThreadInfo;
import java.lang.management.ThreadMXBean;
import java.util.logging.Level;
import java.util.logging.Logger;
import org.graalvm.visualvm.core.VisualVM;
import org.openide.util.NbBundle;
/**
*
* @author Tomas Hurka
*/
public final class ThreadInfoProvider {
private static final Logger LOGGER = Logger.getLogger(ThreadInfoProvider.class.getName());
final private String status;
private boolean useGetThreadInfo;
private ThreadMXBean threadBean;
public ThreadInfoProvider(Application app) {
status = initialize(app);
}
public String getStatus() {
return status;
}
public ThreadMXBean getThreadMXBean() {
return threadBean;
}
private String initialize(Application application) {
if (application.getState() != Stateful.STATE_AVAILABLE) {
return NbBundle.getMessage(ThreadInfoProvider.class, "MSG_unavailable"); // NOI18N
}
JmxModel jmxModel = JmxModelFactory.getJmxModelFor(application);
if (jmxModel == null) {
return NbBundle.getMessage(ThreadInfoProvider.class, "MSG_unavailable_init_jmx"); // NOI18N
}
if (jmxModel.getConnectionState() != JmxModel.ConnectionState.CONNECTED) {
return NbBundle.getMessage(ThreadInfoProvider.class, "MSG_unavailable_create_jmx"); // NOI18N
}
JvmMXBeans mxbeans = JvmMXBeansFactory.getJvmMXBeans(jmxModel);
if (mxbeans == null) {
LOGGER.log(Level.INFO, "JvmMXBeansFactory.getJvmMXBeans(jmxModel) returns null for " + application); // NOI18N
return NbBundle.getMessage(ThreadInfoProvider.class, "MSG_unavailable_threads", VisualVM.getInstance().getLogfileHandle()); // NOI18N
}
////// //TODO
////// // temporary disabled until profiling is rewritten to NB 90
////// return NbBundle.getMessage(ThreadInfoProvider.class, "MSG_unavailable_threads", VisualVM.getInstance().getLogfileHandle()); // NOI18N
threadBean = mxbeans.getThreadMXBean();
if (threadBean == null) {
LOGGER.log(Level.INFO, "mxbeans.getThreadMXBean() returns null for " + application); // NOI18N
return NbBundle.getMessage(ThreadInfoProvider.class, "MSG_unavailable_threads", VisualVM.getInstance().getLogfileHandle()); // NOI18N
}
useGetThreadInfo = JvmFactory.getJVMFor(application).is15();
try {
dumpAllThreads();
} catch (SecurityException e) {
LOGGER.log(Level.INFO, "threadBean.getThreadInfo(ids, maxDepth) throws SecurityException for " + application, e); // NOI18N
return NbBundle.getMessage(ThreadInfoProvider.class, "MSG_unavailable_threads", VisualVM.getInstance().getLogfileHandle()); // NOI18N
} catch (Throwable t) {
LOGGER.log(Level.INFO, "threadBean.getThreadInfo(ids, maxDepth) throws Throwable for " + application, t); // NOI18N
return NbBundle.getMessage(ThreadInfoProvider.class, "MSG_unavailable_threads", VisualVM.getInstance().getLogfileHandle()); // NOI18N
}
return null;
}
ThreadInfo[] dumpAllThreads() {
if (useGetThreadInfo) {
return threadBean.getThreadInfo(threadBean.getAllThreadIds(), Integer.MAX_VALUE);
}
return threadBean.dumpAllThreads(false,false);
}
}