2


我在我的 J2SE 应用程序中使用 Atomikos 基本事务作为我的 TM。
我有以下代码:

if (userTransaction.getStatus()== Status.STATUS_ACTIVE){
userTransaction.commit();
}

然后我在日志中看到以下异常:

java.lang.IllegalStateException:TM_UNIQUE_NAME0003000006 不再处于活动状态,但处于TERMINATED状态 在 com.atomikos.icatch.imp.CoordinatorImp.addParticipant(CoordinatorImp.java:615) 在 com.atomikos.icatch.imp.TransactionStateHandler.addParticipant(TransactionStateHandler.java:133) 在 com.atomikos.icatch.imp.TransactionStateHandler.committed (TransactionStateHandler.java:347) 在 com.atomikos.icatch.imp.TransactionStateHandler.commit(TransactionStateHandler.java:298) 在 com.atomikos.icatch.imp.CompositeTransactionImp.doCommit(CompositeTransactionImp.java:319) 在 com.atomikos。 icatch.imp.CompositeTerminatorImp.commit(CompositeTerminatorImp.java:79) 在 com.atomikos.icatch.jta.TransactionImp.commit(TransactionImp.java:236) 在 com.atomikos.icatch.jta.TransactionManagerImp.commit(TransactionManagerImp.java: 496) 在 com.mycompany.module 的 com.atomikos.icatch.jta.UserTransactionImp.commit(UserTransactionImp.java:129)。view.myOtherClass.transformMpr(myOtherClass.java:57) at java.util.Observable.notifyObservers(Unknown Source) at com.mycompany.module.model.myClass.notifyObservers(myClass.java:291) at com.mycompany.module。 model.myClass.MultiStateEscalation.run(myClass.java:91) at java.util.concurrent.Executors$RunnableAdapter.call(Unknown Source) at java.util.concurrent.FutureTask$Sync.innerRun(Unknown Source) at java.util .concurrent.FutureTask.run(Unknown Source) at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$301(Unknown Source) at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(Unknown Source) at java.util.concurrent。 ThreadPoolExecutor$Worker.runTask(Unknown Source) at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) at java.lang.Thread。运行(未知来源)

其中第 57myOtherClass行是我commit()在上述代码中调用的行。userTransaction 是UserTransaction.
我不明白的是TERMINATED是什么意思?我在 Atomikos 发行版中找不到这些类(这很奇怪,因为它们是开源的,而且我还对所有源代码进行了文本搜索)并且终止不是javax.transaction.Status.
有人遇到过这种情况吗?如何检查我持有的 userTransaction 是否对提交有效?

谢谢,
伊泰

4

1 回答 1

2

TERMINATED 表示已提交或回滚。在您的情况下,很可能是超时/回滚。

如果可以,请尝试增加超时。

一般来说,检查事务状态并不能保证下一行代码可以提交。提交是一个应用程序请求,可能由于超时和资源问题而失败;否则你不需要两阶段提交:-)

最好的

于 2010-12-20T20:42:23.753 回答