我很难理解从 jstack 获得的 Tomcat 6(java 1.6.0_22,Linux)上运行的 Spring MVC Web 应用程序的线程转储。
我看到阻塞线程(导致其他线程等待)本身被阻塞,但是线程转储并没有告诉我原因或它们正在等待哪个监视器。
Example:
"TP-Processor75" daemon prio=10 tid=0x00007f3e88448800 nid=0x56f5 waiting for monitor entry [0x00000000472bc000]
java.lang.Thread.State: BLOCKED (on object monitor)
at java.lang.Class.initAnnotationsIfNecessary(Class.java:3067)
- locked <0x00007f3e9a0b3830> (a java.lang.Class for org.catapultframework.resource.ResourceObject)
at java.lang.Class.getAnnotation(Class.java:3029)
...
IE。我在堆栈跟踪中缺少“等待锁定...”行。显然,线程锁定了一个 Class 对象,但我不明白为什么线程本身被阻塞。
线程转储不包含任何死锁提示。
我可以做什么来识别锁定监视器?
谢谢,
奥利弗
显然,我们观察到的此类阻塞线程的情况与大量内存消耗以及因此产生的大量垃圾收集有关。
这个问题Java 阻塞问题:为什么 JVM 会阻塞许多不同类/方法中的线程? https://stackoverflow.com/questions/4016356/java-blocking-issue-why-would-jvm-block-threads-in-many-different-classes-method描述了类似的情况,所以我相信这些线程只是被垃圾收集器阻止了。
(无论如何,解决内存问题后,阻塞线程的问题就消失了。)
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)