Подтвердить что ты не робот

JTA-контейнер, управляемый транзакцией, не работает для конечной точки jaxrs

Конечная точка отдыха

<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&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>

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.

4b9b3361

Ответ 1

Исходный источник данных объявлен в пакетном пакете, который использует commons-dbcp2. Наконец, я получил эту работу с помощью pax-jdbc-pool-dbcp версии 0.8.0.

Ссылка: https://ops4j1.jira.com/wiki/display/PAXJDBC/Pooling+and+XA+support+for+DataSourceFactory

Спасибо Кристиан Шнайдер за подсказку.