Hibernate 使用Atomikos和Spring集成的事务管理不起作用

Hibernate 使用Atomikos和Spring集成的事务管理不起作用,hibernate,spring-integration,ibm-mq,atomikos,Hibernate,Spring Integration,Ibm Mq,Atomikos,我正在尝试为我的一个项目使用Atomikos全局事务管理,该项目使用spring集成框架读取来自IBM MQ的消息,并将该消息存储在数据库中。虽然应用程序在正常情况下工作,但发生某些DB异常时的行为并不符合预期 在DB异常的情况下,从MQs读取的消息将消失。理想情况下,MQ消息应该在那里进行进一步处理 我使用的Spring配置如下所示: Spring集成配置: <jms:message-driven-channel-adapter id="exch" destination="reques

我正在尝试为我的一个项目使用Atomikos全局事务管理,该项目使用spring集成框架读取来自IBM MQ的消息,并将该消息存储在数据库中。虽然应用程序在正常情况下工作,但发生某些DB异常时的行为并不符合预期

在DB异常的情况下,从MQs读取的消息将消失。理想情况下,MQ消息应该在那里进行进一步处理

我使用的Spring配置如下所示:

Spring集成配置:

<jms:message-driven-channel-adapter id="exch" destination="requestQueue"    channel="jmsInChannel" 
transaction-manager="JtaTransactionManager" acknowledge="transacted" connection-factory="jmsConnectionFactory" />               
<bean id="requestQueue" class="com.ibm.mq.jms.MQQueue">
<property name="baseQueueName" value="${receiving.queue.name}" />   
<property name="targetClient" value="1" />
</bean>

休眠配置:

<bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">                   
<property name="dataSource" ref="dataSource"/>
<property name="hibernateProperties">
<props>
<prop key="hibernate.transaction.jta.platform">
com.atomikos.icatch.jta.hibernate4.AtomikosPlatform
</prop> 
<prop key="hibernate.show_sql">true</prop>
<prop key="hibernate.current_session_context_class">thread</prop>
<prop key="hibernate.jdbc.use_get_generated_keys">true</prop>
<prop key="hibernate.jdbc.lob.non_contextual_creation">true</prop>
<prop key="hibernate.cache.use_query_cache">true</prop>
<prop key="hibernate.cache.use_second_level_cache">true</prop>              
<prop key="hibernate.cache.region.factory_class">org.hibernate.cache.ehcache.EhCacheRegionFactory</prop>                        
</props>
</property>
<property name="annotatedClasses">
<list>
</list>
</property>
</bean>

com.atomikos.icatch.jta.hibernate4.AtomikosPlatform
真的
线
真的
真的
真的
真的
org.hibernate.cache.ehcache.EhCacheRegionFactory
JMS MQ配置:

<bean id="inBoundQueueConnectionFactory"
class="com.ibm.mq.jms.MQXAQueueConnectionFactory">
<property name="hostName">
<value>${receiving.queue.hostname}</value>
</property>
<property name="port">
<value>${receiving.queue.port}</value>
</property>
<property name="queueManager">
<value>${receiving.queue.manager}</value>
</property>
<property name="channel">
<value>${receiving.queue.channel}</value>
</property>
<property name="transportType">
<value>1</value>
</property>
</bean>

<bean id="jmsConnectionFactory" class="org.springframework.jms.connection.CachingConnectionFactory">
<property name="targetConnectionFactory" ref="jmsQueueConnectionFactory"/>
<property name="sessionCacheSize" value="5"/>
<property name="reconnectOnException" value="true"/>
</bean>

<bean id="jmsQueueConnectionFactory"
class="org.springframework.jms.connection.UserCredentialsConnectionFactoryAdapter">
<property name="targetConnectionFactory" ref="inBoundQueueConnectionFactory" />
<property name="username" value="${mqSeriesUserName}" />
<property name="password" value="${mqSeriesPassword}" />
</bean>

<bean id="inBoundConnectionFactory" class="com.atomikos.jms.AtomikosConnectionFactoryBean"> 
<property name="xaConnectionFactory" ref="inBoundQueueConnectionFactory"/> 
<property name="uniqueResourceName" value="mq1"/>   
</bean>

<bean id="atomikosTransactionManager" class="com.atomikos.icatch.jta.UserTransactionManager" init-method="init" destroy-method="close">
<property name="transactionTimeout" value="120"/> 
<property name="forceShutdown">
<value>false</value>
</property>
</bean>

<bean id="atomikosUserTransaction" class="com.atomikos.icatch.jta.UserTransactionImp" >
</bean>

<bean id="JtaTransactionManager" class="org.springframework.transaction.jta.JtaTransactionManager"
depends-on="atomikosTransactionManager,atomikosUserTransaction">
<property name="transactionManager" ref="atomikosTransactionManager" />
<property name="userTransaction" ref="atomikosUserTransaction" />
<property name="allowCustomIsolationLevels" value="true" />
</bean>

${receiving.queue.hostname}
${receiving.queue.port}
${receiving.queue.manager}
${receiving.queue.channel}
1.
假的

如果我在配置中遗漏了什么,请告诉我。

我们看不到您如何为DB操作配置
JtaTransactionManager
。另外,如果DB出现故障,但JMS以任何方式提交,那么在出现该问题时,如果能看到一些
org.springframework
DEBUG
日志,那就太好了。另一方面,不清楚下游流在
jmsInChannel
之后是否是单线程的。可能您正在通过
ExecutorChannel
QueueChannel
等方式将消息转移到新线程。看起来您将错误的连接工厂
jmsConnectionFactory
传递到通道适配器中,而不是Atomikos。我将连接工厂更改为
jmsqueconnectionfactory
&如Artem
所述,添加了以下内容,但我得到以下错误:org.hibernate.engine.transaction.internal.jta.CMTTransaction.transactionManager(CMTTransaction.java:57)org.hibernate.engine.transaction.internal.jta.CMTTransaction.join(CMTTransaction.java:149)在org.hibernate.engine.transaction.internal.TransactionCoordinatorImpl.reset(TransactionCoordinatorImpl.java:128)上,Atlaso尝试编写一个类
AtomikosJtaPlatform扩展AbstractJtaPlatform
,并在hibernate配置中将其作为jta平台。通过该更改,我得到了
hibernateeexception:无法定位当前的JTA事务
我们看不到您如何为DB操作配置
JtaTransactionManager
。另外,如果DB出现故障,但JMS以任何方式提交,那么在出现该问题时,如果能看到一些
org.springframework
DEBUG
日志,那就太好了。另一方面,不清楚下游流在
jmsInChannel
之后是否是单线程的。可能您正在通过
ExecutorChannel
QueueChannel
等方式将消息转移到新线程。看起来您将错误的连接工厂
jmsConnectionFactory
传递到通道适配器中,而不是Atomikos。我将连接工厂更改为
jmsqueconnectionfactory
&如Artem
所述,添加了以下内容,但我得到以下错误:org.hibernate.engine.transaction.internal.jta.CMTTransaction.transactionManager(CMTTransaction.java:57)org.hibernate.engine.transaction.internal.jta.CMTTransaction.join(CMTTransaction.java:149)在org.hibernate.engine.transaction.internal.TransactionCoordinatorImpl.reset(TransactionCoordinatorImpl.java:128)上,Atlaso尝试编写一个类
AtomikosJtaPlatform扩展AbstractJtaPlatform
,并在hibernate配置中将其作为jta平台。通过该更改,我得到了
hibernateeexception:无法找到当前的JTA事务