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&matchOnUriPrefix=true&minThreads=8&maxThreads=16" />
<transacted ref="JTA_TRANSACTION" />
<to uri="jetty:http://127.0.0.1:8080/jaxrs?bridgeEndpoint=true&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不正确.
我想知道是否:
CXF OutFaultInterceptor已"吃掉"应该由容器捕获的异常以进行事务回滚.结果,没有发生回滚.
实体管理器必须是在所有DAO之间共享的相同实例才能实现回滚.
难道我需要将服务分成另一个捆绑包吗?
感谢是否有人可以让我知道cxf jaxrs端点在服务层的事务处理的正确方法.
原始数据源在蓝图包中声明,该蓝图包使用commons-dbcp2。最后,我使用 pax-jdbc-pool-dbcp 版本 0.8.0 完成了这项工作。
参考:https ://ops4j1.jira.com/wiki/display/PAXJDBC/Pooling+and+XA+support+for+DataSourceFactory
感谢克里斯蒂安·施奈德的提示。
| 归档时间: |
|
| 查看次数: |
363 次 |
| 最近记录: |