JTA容器管理的事务回滚不适用于jaxrs端点

all*_*cth 13 jta jax-rs apache-camel aries jbossfuse

休息端点

<jaxrs:server id="jaxrs" 
              address="http://127.0.0.1:8080/jaxrs">

    <jaxrs:serviceBeans>
        <ref component-id="service1" />
        ...
        ...
        <ref component-id="serviceX" />
    </jaxrs:serviceBeans>
    <jaxrs:providers>
        <ref component-id="runtimeExceptionMapper" />
    </jaxrs:providers>
</jaxrs:server>
Run Code Online (Sandbox Code Playgroud)

路线

<route id="secureBridgeRoute">
    <from uri="jetty:https://0.0.0.0:443/jaxrs?sslContextParametersRef=sslContextParameters&amp;matchOnUriPrefix=true&amp;minThreads=8&amp;maxThreads=16" />
    <transacted ref="JTA_TRANSACTION" />
    <to uri="jetty:http://127.0.0.1:8080/jaxrs?bridgeEndpoint=true&amp;throwExceptionOnFailure=true" />
</route>
Run Code Online (Sandbox Code Playgroud)

DAO

<bean id="dao1" class="com.example.Dao1" activation="eager">
    <jpa:context unitname="PU" property="entityManager" type="TRANSACTION" />
</bean>
Run Code Online (Sandbox Code Playgroud)

服务bean

<bean id="service1" class="com.example.Service1" activation="eager">
    <property name="dao1" ref="dao1" />
    <property name="dao2" ref="dao2" />
    <tx:transaction method="*" value="Required" />
</bean>
Run Code Online (Sandbox Code Playgroud)

服务bean方法伪代码

boolean create(entity1, entity2) {
    dao1.persist(entity1);
    dao2.persist(entity2);
}
Run Code Online (Sandbox Code Playgroud)

当dao2持久失败时,事务没有回滚.Entity1被插入到DB中.

附加信息

1)TransactionManager定义

<reference id="platformTransactionManager" interface="org.springframework.transaction.PlatformTransactionManager" />
<bean id="JTA_TRANSACTION" class="org.apache.camel.spring.spi.SpringTransactionPolicy">
    <property name="transactionManager" ref="platformTransactionManager" />
    <property name="propagationBehaviorName" value="PROPAGATION_REQUIRED" />
</bean>
Run Code Online (Sandbox Code Playgroud)

2)我的持久单元是JTA类型,hibernate是提供者.

3)我有一个ExceptionMapper,当我查看它时,stacktrace显示事务确实被标记为回滚.

4)服务bean未分离到另一个包.

5)Hibernate autocommit不正确.

我想知道是否:

  1. CXF OutFaultInterceptor已"吃掉"应该由容器捕获的异常以进行事务回滚.结果,没有发生回滚.

  2. 实体管理器必须是在所有DAO之间共享的相同实例才能实现回滚.

  3. 难道我需要将服务分成另一个捆绑包吗?

感谢是否有人可以让我知道cxf jaxrs端点在服务层的事务处理的正确方法.

all*_*cth 2

原始数据源在蓝图包中声明,该蓝图包使用commons-dbcp2。最后,我使用 pax-jdbc-pool-dbcp 版本 0.8.0 完成了这项工作。

参考:https ://ops4j1.jira.com/wiki/display/PAXJDBC/Pooling+and+XA+support+for+DataSourceFactory

感谢克里斯蒂安·施奈德的提示。