On rare occasions when a MID Server cannot or is slow to pick up messages from the instance, you would like to get a thread dump to troubleshoot. This article describes how to do so. Note that you need to have login access to the MID Server.
How to get thread dump and heap dump
- Download and install a JDK compatible with the MID Server JRE to get the jstack.exe executable from the JDK.
You might run into some unsupported JVM version exceptions if you install the wrong JDK version. Older versions/patches of Oracle JDK are available here. e.g. 8u60 or 8u152.
- Download and unzip PSTools: https://technet.microsoft.com/en-us/sysinternals/bb897553.aspx. You might not have to do this but PsExec is needed to invoke jstack.exe on a process that is run as Local System, which is typical when the MID Server is run as a Windows service.
- Open Task Manager. In 'Processes' tab, sort by Image Name then find 'java.exe' processes. Note the process ID under 'PID' column. If 'PID' column is not shown, goto View > Select Column... and select 'PID' column.
- if multiple MID Servers are running, right click each 'java.exe' process then select Properties, to verify correct MID Server process.
- Open Command Prompt as Administrator change to directory where PSTools is unzipped in step 2. Run the following command to get the MID Server thread dump if MID Server service account is 'SYSTEM':
psexec -s "<path_to_jdk_install>\bin\jstack" -l PID_HERE >> <path_for_generated_file>\threadDump.txtif MID Server service account is a user:
psexec -u <username> "<path_to_jdk_install>\bin\jstack" -l PID_HERE >> <path_for_generated_file>\threadDump.txt
- Run following command to get the heap dump. if MID Server service account is 'SYSTEM':
psexec -s "<path_to_jdk_install>\bin\jmap" -dump:file=<path_for_generated_file>\heapDump.bin PID_HEREif MID Server service account is a user:
psexec -u "<path_to_jdk_install>\bin\jmap" -dump:file=<path_for_generated_file>\heapDump.bin PID_HERE
- Alternately, to dump the heap automatically on out-of-memory exception, modify the wrapper-override.conf file found in the /agent/conf/ directory by adding the following:
"wrapper.app.additional.501=-XX:+HeapDumpOnOutOfMemoryError" OR "wrapper.java.additional.501=-XX:+HeapDumpOnOutOfMemoryError".
***WARNING: This parameter should only be used for short term with active monitoring. As soon as OOM is reproduced and Heapdump is generated, the parameter must be removed. Leaving this parameter in place for extended period can potentially exhaust disk space.
There should be no duplicates in either /agent/conf/wrapper.conf or /agent/conf/wrapper-override.conf files.
Here is an example:
jmap - Memory Map – How to use jmap
jstack - Stack Trace – How to use jstack
Release or Environment
All currently supported releases.