DeadLock Identification from a Single Javacore File in WebSphere on Linux .
Sample Javacore Extracts and Locking Explanation for a DeadLock Condition:
Deadlock detected !!!
Thread "WebContainer : 6" (0x0
is waiting for:
sys_
java
which is owned by:
Thread "Agent Heartbeat" (0x0
which is waiting for:
sys_
com/
which is owned by:
Thread "WebContainer : 29" (0x0
which is waiting for:
sys_
org/
which is owned by:
Thread "WebContainer : 6" (0x0
The above entries from the LOCKS section of Javacore.txt shows a DeadLock condition happened between (3) threads ' WebContainer : 6 ', ' Agent Heartbeat ' and ' WebContainer : 29 '.
Note: When reviewing Systremout.log from WebSphere the profile/logs directory, DeadLocks will most probably show up as WSRV0605W hung thread warning messages
and can only be diagnosed as a "DeadLock" when reviewing the Javacores
in either a text editor or using specialized tooling such as IBM Thread
and Monitor Dump Analyzer for Java.
-->> WebContainer : 6 thread shows an exception happened at spring framework at org/apache/log4j/Category.callAppenders(Category.java:203(Compiled Code))
which is being logged by org/apache/log4j by acquiring the ' root logger ' lock and then this thread is calling a mail service and then being introspected by Wily. For introspection, Wily needs the ' StallSweeper ' lock which is being owned by the " Agent Heartbeat " thread.
Thread Name
WebContainer : 6
State
Deadlock/Blocked
Monitor
Owns Monitor Lock on org/apache/log4j/spi/RootLogger@0x0000000025878DC0
Waiting for Monitor Lock on java/lang/Object@0x000000002D7D8810
Java Stack
at com/wily/introscope/agent/blamestackfeature/BlameStackFeatureBlameStack.IBlameStack_addExtraParameter(BlameStackFeatureBlameStack.java:105(Compiled Code))
at com/wily/introscope/agent/blame/DuplicateHandlingBlameStack.IBlameStack_addExtraParameter(DuplicateHandlingBlameStack.java:60(Compiled Code))
at com/wily/introscope/agent/blame/CompoundBlameStack.IBlameStack_addExtraParameter(CompoundBlameStack.java:165(Compiled Code))
at com/wily/introscope/agent/blame/ComponentTracer.addExtraParameter(ComponentTracer.java:328(Compiled Code))
at com/wily/introscope/agent/blame/ComponentTracer.addExtraParameter(ComponentTracer.java:316(Compiled Code))
at com/wily/introscope/agent/trace/io/SocketBackendTracer.annotateBlameStack(SocketBackendTracer.java:153(Compiled Code))
at java/net/ManagedSocketInputStreamHighPerformance.annotateBlameStack(ManagedSocketInputStreamHighPerformance.java:328(Compiled Code))
at java/net/ManagedSocketInputStreamHighPerformance.read(ManagedSocketInputStreamHighPerfor
-->> WebContainer : 6 thread shows an exception happened at spring framework at org/
which is being logged by org/apache/log4j by acquiring the ' root logger ' lock and then this thread is calling a mail service and then being introspected by Wily. For introspection, Wily needs the ' StallSweeper ' lock which is being owned by the " Agent Heartbeat " thread.
Thread Name
WebContainer : 6
State
Deadlock/Blocked
Monitor
Owns Monitor Lock on org/
Waiting for Monitor Lock on java
Java Stack
at com/
at com/
at com/
at com/
at com/
at com/
at java
at java