我们一直遇到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
任何想法可能导致此问题的原因?
在尝试分配额外的 TLA(线程局部区域)空间时,它似乎卡住了。线程局部区域 (TLA) 是在堆或托儿所上保留的一块可用空间,并提供给线程供其独占使用。线程可以在自己的 TLA 中分配小对象,而无需与其他线程同步。当 TLA 已满时,线程只需请求新的 TLA。线程卡住,因为 jrockit 无法分配内存。
从堆栈跟踪中,当您从数据库中读取数据时会发生这种情况,因此这可能意味着没有足够的 TLA 空间用于读取对象。此查询是否从数据库中读取大量记录?
您可以尝试通过调整 TLA 大小来解决此问题
问题很可能与数据库操作有关:Holding lock: oracle/jdbc/driver/T4CPreparedStatement@0x1d8f8268[thin lock]
。
您是否检查过在服务器遇到上述问题时数据库操作是否正在执行中?
您可以检查以下内容:
- 长时间运行的查询
- 与数据库服务器相关的问题导致数据库响应缓慢
- 尝试从数据库加载大量数据的数据库操作