Jbpm5中的Could not commit session or rollback问题
在jbpm5中创建StatefulKnowledgeSession时,一旦创建过程出错,控制台的错误提示往往如下:Could not commit session or rollback
看似是JtaTransactionManager的相关问题,但实际情况真的如此吗?
其实不然,根据官方回答,这实际上是一个编码失误,用我们看到的异常掩盖了真实的异常。
详情在SingleSessionCommandService.java 的119 - 138行
try {
this.txm.begin();
//this.appScopedEntityManager.joinTransaction();
registerRollbackSync();
jpm.getApplicationScopedPersistenceContext().persist(this.sessionInfo );
this.txm.commit();
} catch ( Exception t1 ) {
try {
this.txm.rollback();//事务回滚,但原始异常丢失了
} catch ( Throwable t2 ) {
throw new RuntimeException( "Could not commit session or rollback", t2 );//这是我们看到的异常
}
throw new RuntimeException( "Could not commit session", t1 );
}
所以,如果我们在调试中遇到这个异常,就需要下载drool-jbpm源码包
点此下载
来进行断点跟踪调试