Monitor and diagnose performance in Java se 6 — reprint

Java SE 6 provides an in-depth focus on performance,offering expanded tools for managing and monitoring applications and for diagnosing common problems. The improvements include:

This article outlines the basis of monitoring and management in the Java SE platform and provides detailed information about the performance monitoring and management enhancements in the latest release. It also describes the diagnostic and troubleshooting tools available in the Java SE 6 platform.

To benefit from this article,you should have a strong understanding of the monitoring and management functionality introduced in prevIoUs Java SE releases. See for detailed background information.

The java. lang.management package introduced in Java SE 5 defines nine MBeans called platform MBeans,or MXBeans (see ). Each MXBean encapsulates a single functional area of the JVM. Beginning with Java SE 5,the JVM has included a built-in MBean server called the platform MBean server. MBeans reside in and are managed by this repository. Table 1 outlines the nine MXBeans in the Java platform:

ClassLoadingMXBean CompilationMXBean MemoryMXBean ThreadMXBean RuntimeMXBean OperatingSystemMXBean rating sy stem GarbageCollectorMXBean MemoryManagerMXBean MemoryPoolMXBean Any application can obtain and use the JVM-provided platform MBeans by obtaining an instance of the desired bean and invoking the appropriate methods. MXBeans can be used to monitor the behavior of both local and remote JVMs and retrieve information about them. Platform MBeans provide access to information such as the number of classes loaded,uptime of the JVM,the amount of memory consumed,and the number of threads running,as well as statistics about thread contention. You can monitor and manage the JVM resources in one of two ways: Direct access to the MXBean interface Indirect access using the MBeanServer interface You can retrieve an MXBean instance from a static factory method that gives you direct access to the locally running JVM's MXBean interface. TheManagementFactory class provides the static factory methods for obtaining the MXBeans. The example in Listing 1 demonstrates how to retrieve the RuntimeMXBean using this factory and get the value of one of its standard attributes: VmVendor: // Get the standard attribute "VmVendor" String vendor = mxbean. getVmVendor(); The platform MBeanServer interface uses MXBeanServerConnection to allow you to connect to remote JVMs and access MXBeans running on those platforms. You can use the ManagementFactory class's getPlatformMBeanServer method to access the platform MBean server. Listing 2 demonstrates how to get the RuntimeMXBean running in a remote JVM and get the value of its VmVendor attribute: try { //connect to a remote VM using JMX RMI JMXServiceURL url = new JMXServiceURL( "service:jmx: rmi:///jndi/rmi:// "); JMXConnector jmxConnector = JMXConnectorFactory.connect(url); serverConn = jmxConnector.getMBeanServerConnection(); ObjectName objName = new ObjectName(ManagementFactory.RUNTIME_MXBEAN_NAME); // Get standard attribute "VmVendor" String vendor = (String) serverConn.getAttribute(objName,"VmVendor"); } catch (...) { } See for more detailed information on MXBeans and the java. lang.management API. Java SE 5 introduced the java. util. concurrent. locks package,which provides a framework for lock and wait conditions. This framework is distinct from Java's built-in synchronization support and allows greater flexibility in the use of locks. Java SE 6 adds support for java. util. concurrent. locks in the java. lang.management package. This includes new classes that provide information about locks,as well as enhancements to the ThreadInfo, ThreadMXBean,and OperatingSystemMXBean interfaces. Java SE 6 introduces two new classes: LockInfo contains information about a lock. MonitorInfo extends LockInfo and contains information about an object-monitor lock. The ThreadInfo class makes use of these new objects with the introduction of three new methods: getLockInfo() returns the LockInfo object for which the given thread is blocked waiting. getLockedMonitors() returns the MonitorInfo objects that are currently locked by the given thread. getLockedSynchronizers() returns the LockInfo objects,representing ownable synchronizers that are currently locked by the given thread. In Java SE 5,the ThreadMXBean. getThreadInfo methods report only an object monitor that a thread is waiting to acquire or is blocked from entering. In Java SE 6,these methods are enhanced to report the AbstractOwnableSynchronizer that a thread is waiting to acquire. Four new methods have been added to the ThreadMXBean interface: isObjectMonitorUsageSupported() tests if the virtual machine supports monitoring the usage of object monitors. isSynchronizerUsageSupported() tests if the virtual machine supports monitoring the usage of ownable synchronizers. findDeadlockedThreads() returns an array of thread IDs that are deadlocked. Threads that are deadlocked are blocking one another from entering an object monitor or synchronizer. dumpAllThreads() returns stack-trace and synchronization information for all live threads. Finally,the OperatingSystemMXBean interface was updated to include the getSystemLoadAverage() method,which returns the system load average for the past minute. In addition to this programmatic support,Java SE 6 also includes several diagnostic and troubleshooting tools that can be used to detect problems and monitor usage of JVM resources. The next two sections describe and demonstrate some of the available diagnostic tools. Java SE 6 includes official support for JConsole,a monitoring and management console introduced in Java SE 5. JConsole lets you monitor various JVM resource statistics during run time. It's particularly useful for detecting symptoms of deadlocks,lock contention,memory leaks,and cycling threads. It can connect to a local or remote JVM and can be used to monitor: Thread state (including associated locks) Memory usage Garbage collection Runtime information JVM information The following subsections describe the enhancements made to JConsole in Java SE 6. See for more information on how to start and use JConsole. Beginning in Java SE 6,JConsole implements the new Attach API. This API consists of two packages —com. sun. tools. attach andcom. sun. tools. attach. spi— that let implementing applications dynamically attach to a target virtual machine and run their agents within that JVM. In the past,applications that you wanted to monitor with JConsole needed to be started with the -Dcom. sun. management. jmxremote option; applications no longer need to start with this option. Support for dynamic attachment makes JConsole capable of monitoring any application that supports the Attach API. Compliant applications are automatically detected when JConsole starts up. In Java SE 6,JConsole has been updated to have a look and feel similar to the Windows ® operating system or GNOME desktop,depending on which platform it's running on. The screenshots shown throughout the rest of this article were taken on Windows XP and show the UI features that have changed from the prevIoUs release. Once started and associated with an application,the JConsole view consists of six tabs,each representing a different JVM resource or set of resources: Overview Memory Threads Classes VM Summary MBeans The Overview tab displays correlated information about memory usage,threads,classes,and cpu usage in a graphical format. The Overview tab displays a set of related information on one page that was available prevIoUsly only by switching among multiple tabs. figure 1 shows the Overview tab for a sample application: The Overview tab displays four graphs of VM resource-usage information as well as a pick list for altering the time range for which you would like to see results. The first graph,Heap Memory Usage,displays the amount of heap memory that has been used in megabytes over time. This graph is useful in detecting memory leaks. If a memory leak is present in your application,the heap memory usage steadily increases over time. The Threads graph plots the number of live threads over time,and the Classes graph depicts the number of classes loaded. The CPU Usage chart depicts the percentage of the CPU your application uses at various points in its life cycle. The VM Summary tab,shown in Figure 2,is another new addition to the Java SE 6 release. It provides detailed information about the JVM,including total uptime,threading information,classes loaded,memory statistics,garbage collection,and operating-system information. The MBeans tab has been improved to allow for easier access to your MBeans' operations and attributes. It displays information about all MBeans registered with the platform. All platform MBeans are accessible through this tab. The tree structure along the left-hand side displays all currently running MBeans. When you select an MBean,its MBeanInfo and descriptor are displayed on the table to the right,as shown in figure 3: Selecting the Attributes node displays all the MBean's attributes,as shown in figure 4 for the Threading MBean: Note that the attributes and their values shown in the @R_ 166_ 2419@ to the right map to the attribute values attainable through the ThreadMXBean API in thejava. lang.management package prevIoUsly described. You can obtain additional information about a listed attribute by double-clicking on the attribute value. Only attribute values shown in bold can be expanded. For example,double-clicking on the AllThreadIds value displays the thread IDs of all 22 threads,as shown in figure 5: Writeable attributes are displayed in blue and you can edit them by clicking on them and entering the new value. For example,theThreadContentionMonitoringAvailable attribute shown in figure 5 can be edited in this manner from the JConsole view. Selecting the Operations node in the left-hand tree structure displays the operations associated with that MBean. The MBean operations appear as buttons in the right-side display and,when clicked on,invoke the specified method. figure 6 shows the operations available for ThreadMXBean: In Java SE 6,JConsole includes support for the HotSpot Diagnostic MBean. This MBean was introduced in this release to allow you to perform on-the-spot diagnostic operations. Its API lets users perform a heap dump and set other VM options during run time. You can access the HotSpot Diagnostic MBean from the MBean tab by expanding the com. sun. management node and selecting HotSpotDiagnostic. Methods available from the HotSpot Diagnostic MBean are shown in figure 7: Beginning in Java SE 6,JConsole includes plug-in support that allows you to build your own plug-ins to run with JConsole. For example,you can add a custom tab to the JConsole main view for accessing application-specific MBeans and for performing your own monitoring activities. You must extend the abstract com. sun. tools. jconsole. JConsolePlugin class to create a custom JConsole plug-in. You implement two methods for a plug-in to appear properly in the JConsole view: newSwingWorker() returns a SwingWorker object that performs the GUI updates for your plug-in. getTabs() returns a map of tabs to be added to the JConsole window. JConsole uses its service-provider mechanism to detect and load all plug-in classes. For this reason
The content of this article comes from the network collection of netizens. It is used as a learning reference. The copyright belongs to the original author.
THE END
分享
二维码
< <上一篇
下一篇>>