3

在这个线程转储中:

INFO   | jvm 3    | 2011/06/08 13:36:12 | "ExecuteThread: '38' for queue: 'default'" id=55 idx=0x78 tid=5316 prio=5 alive, in native, waiting, daemon
INFO   | jvm 3    | 2011/06/08 13:36:12 |     -- Waiting for notification on: weblogic/ejb20/locks/ExclusiveLockManager$LockWaiter@0x25EF8828[fat lock]
INFO   | jvm 3    | 2011/06/08 13:36:12 |     at jrockit/vm/Threads.waitForSignal(J)Z(Native Method)
INFO   | jvm 3    | 2011/06/08 13:36:12 |     at java/lang/Object.wait(J)V(Native Method)[optimized]
INFO   | jvm 3    | 2011/06/08 13:36:12 |     at weblogic/ejb20/locks/ExclusiveLockManager$LockBucket.lock(Ljava/lang/Object;Ljava/lang/Object;I)Z(ExclusiveLockManager.java:504)[optimized]
INFO   | jvm 3    | 2011/06/08 13:36:12 |     ^-- Lock released while waiting: weblogic/ejb20/locks/ExclusiveLockManager$LockWaiter@0x25EF8828[fat lock]
INFO   | jvm 3    | 2011/06/08 13:36:12 |     at weblogic/ejb20/locks/ExclusiveLockManager.lock(Ljava/lang/Object;Ljava/lang/Object;I)Z(ExclusiveLockManager.java:261)[optimized]
INFO   | jvm 3    | 2011/06/08 13:36:12 |     at weblogic/ejb20/manager/ExclusiveEntityManager.acquireLock(Ljava/lang/Object;Ljavax/transaction/Transaction;I)Z(ExclusiveEntityManager.java:210)[inlined]
INFO   | jvm 3    | 2011/06/08 13:36:12 |     at weblogic/ejb20/manager/ExclusiveEntityManager.getReadyBean(Ljava/lang/Object;Ljavax/transaction/Transaction;I)Ljavax/ejb/EntityBean;(ExclusiveEntityManager.java:267)[inlined]
INFO   | jvm 3    | 2011/06/08 13:36:12 |     at weblogic/ejb20/manager/ExclusiveEntityManager.preInvoke(Lweblogic/ejb20/internal/InvocationWrapper;)Ljavax/ejb/EnterpriseBean;(ExclusiveEntityManager.java:242)[optimized]
INFO   | jvm 3    | 2011/06/08 13:36:12 |     at weblogic/ejb20/internal/BaseEJBObject.preInvoke(Lweblogic/ejb20/internal/InvocationWrapper;Lweblogic/security/service/ContextHandler;)Lweblogic/ejb20/internal/InvocationWrapper;(BaseEJBObject.java:152)[inlined]
INFO   | jvm 3    | 2011/06/08 13:36:12 |     at weblogic/ejb20/internal/EntityEJBObject.preInvoke(Lweblogic/ejb20/internal/MethodDescriptor;Lweblogic/security/service/ContextHandler;)Lweblogic/ejb20/internal/InvocationWrapper;(EntityEJBObject.java:104)[inlined]
INFO   | jvm 3    | 2011/06/08 13:36:12 |     at foob/ejb/commodity/ejb_Commodity_etfd4i_EOImpl.getData()Lfoob/ejb/commodity/db/CommodityData;(ejb_Commodity_etfd4i_EOImpl.java:701)[optimized]
INFO   | jvm 3    | 2011/06/08 13:36:12 |     at foob/ejb/item/OurItem.loadCommodityData()V(OurItem.java:172)[optimized]
INFO   | jvm 3    | 2011/06/08 13:36:12 |     ^-- Holding lock: java/lang/Class@0x067EA070[fat lock]
INFO   | jvm 3    | 2011/06/08 13:36:12 |     at foob/ejb/item/OurItem.getCommodityData()Lfoob/ejb/commodity/db/CommodityData;(OurItem.java:251)
INFO   | jvm 3    | 2011/06/08 13:36:12 |     at foob/ejb/item/OurItem.getTheControlGid()Ljava/lang/String;(OurItem.java:259)
INFO   | jvm 3    | 2011/06/08 13:36:12 |     at foob/business/shipment/OurThing.getTheControlGid(Lfoob/util/jdbc/OurConnection;)Ljava/lang/String;(OurThing.java:379)

线是做什么的

Lock released while waiting: weblogic/ejb20/locks/ExclusiveLockManager$LockWaiter@0x25EF8828

意思是?我们有 8 个其他线程被阻塞等待java/lang/Class@0x067EA070被释放,这个线程正在持有,但我不明白这个线程阻塞了什么,也不知道锁被释放是什么意思。我会认为线程转储是一种停止世界类型的事件,因此有问题的行不会指线程转储发生时释放的锁......

此外,它出现的位置是否有任何意义(即它上面和下面的线)?

显然我不是 Java 期望,所以我希望这不是一个太愚蠢的问题。谢谢您的帮助!

4

3 回答 3

2

Oracle JRockit JDK 工具指南

Java 中等待(通知)对象的语义有些复杂。首先,要进入同步块,您必须为该对象获取锁,然后对该对象调用 wait()。在等待方法中,锁在线程进入睡眠等待通知之前被释放。当线程收到通知时,wait() 在返回之前重新获取锁。如果线程已获取锁,并且正在等待有关该锁的通知,则堆栈跟踪中描述何时获取锁的行不会显示为 (Holding lock);它显示为(等待时释放锁定。)

换句话说,这意味着所述线程有一个对象,该对象较早获得了锁,然后在调用时释放了它object.wait()。与行为类似的代码模式是:

synchronized(lock) //acquires the lock
{
   ...
   do some work
   ...
   object.wait(); //releases the lock, and waits for a notification
}

更新

在查看堆栈跟踪时,您似乎正在使用实体 EJB Bean,并且考虑到此类实现的操作方式,通常会在实体 EJB 上获取锁。这实际上取决于用于管理必须访问数据库的并发事务的并发策略。我怀疑 bean 的数量要么太少,要么只有一个 bean 可以锁定。

于 2011-06-15T14:27:21.050 回答
1

在此页面上搜索“锁定已释放”,它可以很好地解释在等待对象的逻辑中发生的事情。

http://download.oracle.com/docs/cd/E13188_01/jrockit/docs142/userguide/apstkdmp.html

看来,此消息表示获得 notify() 的原始 wait() 调用重新捕获对象的锁。

为了将来参考,我只是通过谷歌搜索“等待时释放锁定”找到了这个,这是出现的第一页……希望你已经在网上搜索过,只是对你的内容不满意找到了,在这种情况下,如果这没有帮助,我很抱歉。

于 2011-06-15T14:22:37.400 回答
0

它很可能与上面的两行条目有关:

at java/lang/Object.wait(J)V(Native Method)[optimized]

wait() 将释放当前持有的锁(被周围同步块持有的锁)并等待一个 notify() 信号。

于 2011-06-15T14:22:10.740 回答