Конечная точка отдыха
<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>
Маршрут
<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>
DAO
<bean id="dao1" class="com.example.Dao1" activation="eager">
<jpa:context unitname="PU" property="entityManager" type="TRANSACTION" />
</bean>
Сервис 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>
Сервис bean псевдокод метода
boolean create(entity1, entity2) {
dao1.persist(entity1);
dao2.persist(entity2);
}
Когда dao2 persist failed failed, транзакция не откатется. Entity1 вставляется в БД.
Дополнительная информация
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>
2) Мое постоянное устройство имеет тип JTA и спящий режим в качестве поставщика.
3) У меня есть ExceptionMapper, который, когда я смотрю на него, показывает, что транзакция действительно отмечена для отката.
4) Служба beans не разделена на другой пакет.
5) Hibernate autocommit не является истинным.
Мне интересно, если:
-
CXF OutFaultInterceptor "съел" исключение, которое предполагается поймать контейнером для откат транзакции. В результате откат не произошел.
-
Диспетчер сущностей должен быть одним и тем же экземпляром, совместно используемым всеми DAO, для того, чтобы выполнить откат.
-
Может быть, мне нужно отделить службу от другого пакета?
Оцените, сможет ли кто-нибудь сообщить мне правильный подход при обработке транзакций на уровне сервиса для конечной точки cxf jaxrs.