Jbpm5中的Could not commit session or rollback有关问题

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源码包
点此下载
来进行断点跟踪调试