JRockit卡住了

时间:2013-01-25 20:27:12

标签: weblogic jrockit

我们一直遇到JRockit jvm陷入困境的问题:

"[STUCK] ExecuteThread: '2' for queue: 'weblogic.kernel.Default (self-tuning)'" id=45 idx=0x94 tid=9944 prio=1 alive, in native, daemon
    at jrockit/vm/Allocator.nativeGetNewTLA()V(Native Method)
    at jrockit/vm/Allocator.getNewTLA(Allocator.java:788)[optimized]
    at jrockit/vm/Allocator.allocLargerThanFreeTLA(Allocator.java:816)[inlined]
    at jrockit/vm/Allocator.allocSlowCaseInner(Allocator.java:930)[inlined]
    at jrockit/vm/Allocator.allocSlowCase(Allocator.java:776)[optimized]
    at oracle/jdbc/driver/T4CMAREngine.unmarshalCLRforREFS(T4CMAREngine.java:2024)[optimized]
    at oracle/jdbc/driver/T4CTTIoer.unmarshal(T4CTTIoer.java:160)[optimized]
    at oracle/jdbc/driver/T4C8Oall.receive(T4C8Oall.java:727)[optimized]
    at oracle/jdbc/driver/T4CPreparedStatement.doOall8(T4CPreparedStatement.java:216)[inlined]
    at oracle/jdbc/driver/T4CPreparedStatement.executeForRows(T4CPreparedStatement.java:955)[optimized]
    at oracle/jdbc/driver/OracleStatement.executeMaybeDescribe(OracleStatement.java:1060)[optimized]
    at oracle/jdbc/driver/T4CPreparedStatement.executeMaybeDescribe(T4CPreparedStatement.java:839)[optimized]
    at oracle/jdbc/driver/OracleStatement.doExecuteWithTimeout(OracleStatement.java:1132)[optimized]
    at oracle/jdbc/driver/OraclePreparedStatement.executeInternal(OraclePreparedStatement.java:3316)[optimized]
    at oracle/jdbc/driver/OraclePreparedStatement.executeQuery(OraclePreparedStatement.java:3361)[optimized]
    ^-- Holding lock: oracle/jdbc/driver/T4CPreparedStatement@0x1d8f8268[thin lock]
    ^-- Holding lock: oracle/jdbc/driver/T4CConnection@0x14d68fd8[thin lock]
    at weblogic/jdbc/wrapper/PreparedStatement.executeQuery(PreparedStatement.java:97)[optimized]

似乎在试图分配内存时遇到困难。根据我们的监控工具,在服务器卡住之前,堆使用率约为14%且不到20%。

这是java版本:

java version "1.5.0_14"
Java(TM) 2 Runtime Environment, Standard Edition (build 1.5.0_14-b03)
BEA JRockit(R) (build R27.5.0-110_o-99226-1.5.0_14-20080528-1505-linux-x86_64, compiled mode)

这些是我们正在使用的JVM设置

-Xms256m -Xmx3072m -Xverify:none 

任何可能导致此问题的想法?

2 个答案:

答案 0 :(得分:3)

在尝试分配额外的TLA(线程局部区域)空间时,它看起来像是卡住了。线程局部区域(TLA)是在堆或托儿所上保留的一块可用空间,并且被提供给线程以供其专用。线程可以在自己的TLA中分配小对象,而无需与其他线程同步。当TLA变满时,线程只需要一个新的TLA。 由于jrockit无法分配内存,线程卡住了。

从堆栈跟踪中,当您从数据库中读取数据时会发生这种情况,因此可能意味着读取对象没有足够的TLA空间。此查询是否从数据库中读取了大量记录?

您可以尝试tuning the TLA size

解决此问题

答案 1 :(得分:1)

问题很可能与数据库操作有关:Holding lock: oracle/jdbc/driver/T4CPreparedStatement@0x1d8f8268[thin lock]

您是否检查过服务器遇到上述问题时是否正在执行数据库操作?

您可以查看以下内容:

  • 长时间运行查询
  • 与DB服务器相关的问题导致数据库缓慢响应
  • 尝试从DB
  • 加载大块数据的DB操作