我有使用 BMT 的 bean。另一个使用 BMT 的 bean 被注入到第一个中。现在,当第一个调用第二个的方法时,事务突然关闭。在我的代码中,我将其范围缩小到方法调用之前及其内部的确切位置。
这是跟踪:
2018-11-23 12:15:32,275 +0100 [TRACE] [com.arjuna.ats.jta](默认任务 18)TransactionImple.getStatus:javax.transaction.Status.STATUS_ACTIVE
2018-11-23 12:15:32,276 +0100 [TRACE] [com.arjuna.ats.jta](默认任务 18)TransactionImpleManager.suspend
2018-11-23 12:15:32,277 +0100 [TRACE] [com.arjuna.ats.jta](默认任务 18)TransactionSynchronizationRegistryImple.getTransactionKey
示例代码:
@Stateless
@TransactionManagement(TransactionManagementType.BEAN)
public class A{
@Inject
private B b;
@Inject
private UserTransaction trx;
public void foo(){
trx.begin();
//transaction is active
b.bar();
trx.commit();
}
}
@Stateless
@TransactionManagement(TransactionManagementType.BEAN)
public class B{
public void bar(){
//transaction is closed
//whatever
}
}
发生在 JBoss EAP 7.0.9 上。
我在很多地方都有这个星座,但只有在这里它坏了。我错过了一些基本的东西吗?我在哪里可以找到更多线索?