1

我们正在使用带有 jrockit 1.6 64 位的 Weblogic 10.3.2,我们的应用程序正在使用 jboss seam 框架。卡住的线程数量正在稳步增加。这些卡住的线程只是在等待,它们没有花费任何 cpu 周期。所有卡住线程的堆栈跟踪都是相同的,它们的状态是 native_waiting。

最后一个 java 方法调用是 com/sun/faces/application/ViewHandlerImpl.renderView(ViewHandlerImpl.java:186). 这是 ViewHandlerImpl 类的第 186 行的源代码;

  WriteBehindStateWriter stateWriter =
          new WriteBehindStateWriter(response.getWriter(),
                                     context,
                                     bufSize);

此电子邮件附有完整的堆栈跟踪。这是一些卡住线程的堆栈跟踪;

"[STUCK] ExecuteThread: '29' for queue: 'weblogic.kernel.Default (self-tuning)'" id=127 idx=0x230 tid=6974 prio=1 alive, native_waiting, daemon
    at pthread_cond_wait@@GLIBC_2.3.2+185(:0)@0x3820a0aee9
    at eventTimedWaitNoTransitionImpl+71(event.c:90)@0x2b1ffc771ec8
    at syncWaitForSignalNoTransition+65(synchronization.c:28)@0x2b1ffc904312
    at innerNativeDoWait+1112(nativelock.c:614)@0x2b1ffc893f99
    at nativeWait+54(nativelock.c:721)@0x2b1ffc8942a7
    at clsEnsureInitialized+378(class.c:222)@0x2b1ffc72c61b
    at RJNI_jrockit_vm_RNI_initializeClass+19(trampoline.c:106)@0x2b1ffc90aba4
    at jrockit/vm/RNI.initializeClass(J)V(Native Method)
    at com/sun/faces/application/ViewHandlerImpl.renderView(ViewHandlerImpl.java:186)
    at org/jboss/seam/jsf/SeamViewHandler.renderView(SeamViewHandler.java:87)
    at com/sun/facelets/FaceletViewHandler.renderView(FaceletViewHandler.java:547)[optimized]
    at org/ajax4jsf/application/ViewHandlerWrapper.renderView(ViewHandlerWrapper.java:100)[inlined]
    at org/ajax4jsf/application/AjaxViewHandler.renderView(AjaxViewHandler.java:176)[optimized]
    at com/sun/faces/lifecycle/RenderResponsePhase.execute(RenderResponsePhase.java:109)[optimized]
    at com/sun/faces/lifecycle/Phase.doPhase(Phase.java:100)[optimized]



"[STUCK] ExecuteThread: '28' for queue: 'weblogic.kernel.Default (self-tuning)'" id=126 idx=0x22c tid=6973 prio=1 alive, native_waiting, daemon
    at pthread_cond_wait@@GLIBC_2.3.2+185(:0)@0x3820a0aee9
    at eventTimedWaitNoTransitionImpl+71(event.c:90)@0x2b1ffc771ec8
    at syncWaitForSignalNoTransition+65(synchronization.c:28)@0x2b1ffc904312
    at innerNativeDoWait+1112(nativelock.c:614)@0x2b1ffc893f99
    at nativeWait+54(nativelock.c:721)@0x2b1ffc8942a7
    at clsEnsureInitialized+378(class.c:222)@0x2b1ffc72c61b
    at RJNI_jrockit_vm_RNI_initializeClass+19(trampoline.c:106)@0x2b1ffc90aba4
    at jrockit/vm/RNI.initializeClass(J)V(Native Method)
    at com/sun/faces/application/ViewHandlerImpl.renderView(ViewHandlerImpl.java:186)
    at org/jboss/seam/jsf/SeamViewHandler.renderView(SeamViewHandler.java:87)
    at com/sun/facelets/FaceletViewHandler.renderView(FaceletViewHandler.java:547)[optimized]
    at org/ajax4jsf/application/ViewHandlerWrapper.renderView(ViewHandlerWrapper.java:100)[inlined]
    at org/ajax4jsf/application/AjaxViewHandler.renderView(AjaxViewHandler.java:176)[optimized]
    at com/sun/faces/lifecycle/RenderResponsePhase.execute(RenderResponsePhase.java:109)[optimized]
    at com/sun/faces/lifecycle/Phase.doPhase(Phase.java:100)[optimized]
    at com/sun/faces/lifecycle/LifecycleImpl.render(LifecycleImpl.java:139)[optimized]
    at javax/faces/webapp/FacesServlet.service(FacesServlet.java:266)[optimized]
    at weblogic/servlet/internal/StubSecurityHelper$ServletServiceAction.run(StubSecurityHelper.java:227)[optimized]
    at weblogic/servlet/internal/StubSecurityHelper.invokeServlet(StubSecurityHelper.java:125)[inlined]
    at weblogic/servlet/internal/ServletStubImpl.execute(ServletStubImpl.java:292)[optimized]

你知道为什么这些线程在等待吗?...

4

0 回答 0