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.
If the default JDK/JRE does not have jmap installed, here is a known JDK with jmap bundled:
*** NOTE: If downloading the above JDK, you do not need to make any configuration changes on the MID server (e.g: changing the MID server run time environment). For the commands below you would just execute the commands from the downloaded JDK path.
- (If gathering thread dump) 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.
- (If gathering thread dump) Open Command Prompt as Administrator change to directory where PSTools is unzipped in step 2. Run the following command 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
- (If gathering heap dump) Run this command:
<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.