A list,

The bin folder in the JDK installation directory provides several visual monitoring tools in addition to command line monitoring tools to help users intuitively learn about VM running status. Common visual monitoring tools are as follows:

Second, the JConsole

2.1 introduction

Java Monitoring and Management Console (JConsole) is a visual Monitoring tool based on Java Manage-ment Extensions (JMX). Its main function is to collect system information and dynamically adjust system parameters through JMX’s Mbeans (Managed beans). JMX (Java Management Extensions) is a framework for implementing Management functions for applications, devices, and systems. JMX is usually used to monitor the running status of the system or manage some functions of the system.

2.2 the use of

When you open the JConsole program in the bin directory, it automatically scans all JVM processes on the current host:

Select the process that you want to monitor and click Connect to enter the monitoring page. The monitor interface consists of six tabs: Overview, Memory, Threads, classes, VM Profiles, and MBeans. The overview interface displays the overview information of the three TAB interfaces, including memory, thread and class, as shown below:

The memory interface is mainly used to display the usage of various regions on the heap and non-heap:

The thread interface mainly displays the stack information of each thread. There is a deadlock detection button in the bottom corner. If the deadlock is detected after clicking, the deadlock TAB will appear next to the thread TAB below:

Click the deadlock TAB to see the thread causing the deadlock:

The final classes TAB is mainly used to display the number of classes currently loaded and unloaded. The VM Profile TAB is mainly used to display VM parameters, as shown below:

Third, VisualVM

3.1 introduction

VisualVM (All-In-one Java Troubleshooting Tool) is One of the most powerful runtime monitoring and Troubleshooting programs provided by Oracle. In addition to supporting normal runtime monitoring and Troubleshooting functions, It can also be used for Profiling. And because VisualVM is a NetBeans platform based development tool, it also supports extensibility through plug-ins. The main features of VisualVM are as follows:

  • Displays VM processes, configuration information, and environment information (similar to the JPS and jINFO functions).
  • Monitor the application’s processor, garbage collection, heap, method area, and thread information (similar to jstat and JStack capabilities);
  • Dump and analyze heap dump snapshots (similar to jMAP and JHAT);
  • Method-level program performance analysis to find out the most called and longest running methods;
  • Offline program snapshot: You can collect program runtime configuration, thread dump, memory dump, and other information to create a snapshot.

3.2 the use of

Open the JVisualVM program in the bin directory, which automatically scans all JVM processes on the current host:

After you click the process to be monitored, related monitoring information is displayed on the right:

1. The heap Dump

Click the button in the monitoring interface to perform garbage collection or heap Dump. After heap Dump, the analysis results are also displayed:

2. Thread Dump

In the thread interface, you can view the status of all threads. If a deadlock occurs, the interface will also inform you:

In this case, thread Dump can be performed to obtain specific thread information, similar to the effect of the jstack command:

3. Performance analysis

In the Profiler interface, you can perform CPU and memory performance analysis. To start performance analysis, you need to select either the CPU or memory buttons, and VisualVM will start recording all methods executed by the application: if CPU execution time analysis is performed, it will count the number of times each method was executed and the execution time; In the case of memory analysis, the number of objects associated with each method and the space occupied by those objects is counted. To end performance analysis, click the Stop button:

4. Visual GC

The Visual GC panel is not displayed by default and needs to be extended through plug-ins. It monitors virtual machine status in real time and is functionally similar to the jstat command:

3.3 Installing Plug-ins

On the main screen, click Tools => Plug-ins to open the plug-in panel. Right click the plug-in option or click the Install button to complete the installation of the corresponding plug-in:

Note that you need to configure the plug-in center according to your JVM version before installing the plug-in. Otherwise, an exception “cannot connect to the plug-in center” will be thrown. Each version of the corresponding plug-in center can look up on the website: visualvm. Making. IO/pluginscent…

Then you need to configure the correct plug-in center address into the program:

4. Connect to remote processes

In the JConsole and VisualVM demonstrations above, we used local processes, but in real development, we need to monitor more remote processes on the server. To monitor processes on a remote host, you need to configure JMX. You can configure JMX in either of the following ways based on whether a user name and password are required:

4.1 Do not use security credentials

Add the following parameters when starting a Java process on the server:

Java - Dcom. Sun. Management. Jmxremote. Port = 12345 # JMX remote connection port number - Dcom. Sun. Management jmxremote. SSL = false -Dcom.sun.management.jmxremote.authenticate=false -jar springboot.jarCopy the code

In this case, you only need to know the host address and port number to connect, and do not need to use the user name and password, so the security is low.

4.2 Using security Credentials

Add the following parameters when starting a Java process on the server:

java -Dcom.sun.management.jmxremote.port=12345 
-Dcom.sun.management.jmxremote.ssl=false 
-Dcom.sun.management.jmxremote.authenticate=true 
-Dcom.sun.management.jmxremote.access.file=/usr/local/jmxremote.access 
-Dcom.sun.management.jmxremote.password.file=/usr/local/jmxremote.password 
-jar springboot.jar 
Copy the code

The contents of jmxremote.access are as follows, where admin is the user name and readwrite indicates that the user can read or write, or the value can be set to readonly:

admin readwrite  
Copy the code

Jmxremote. password contains the following contents, where admin is the user name and 123456 is the password:

admin 123456
Copy the code

After the two files are created, you need to grant the execute permission to them:

chmod 600 /usr/local/jmxremote.access
chmod 600 /usr/local/jmxremote.password
chown root:root /usr/local/jmxremote.access
chown root:root /usr/local/jmxremote.password
Copy the code

Then when using VisualVM for remote connection, the configuration is as follows:

It is important to note the port number here is configured Dcom. Sun. Management jmxremote. Port values, rather than a Java program of the port. After the connection is complete, you can view the monitoring status of the process.

The resources

  1. An In-depth Understanding of Java Virtual Machines (3rd edition). China Machine Press, 2019-12. For an in-depth understanding of virtual machines, we recommend reading the original book.
  2. Visualvm official document: visualvm. Making. IO/documentati…
  3. Java_jvisualvm uses JMX to connect to remote machines (practice)
  4. Remotely monitor the Tomcat service through a firewall using JMX

For more articles, please visit the full stack Engineer manual at GitHub.Github.com/heibaiying/…