可以在spring批处理中使用jobRepository来使用本地事务但在分布式XA事务中执行特定的作业步骤吗?
对于XA,我使用Atomicos 3.8.0。步骤应该是在处理后读取JMS消息并更新数据库。
弹簧配置的相关部分:
<job id="job" xmlns="http://www.springframework.org/schema/batch">
<step id="inventorySync">
<tasklet transaction-manager="xaTransactionManager">
<chunk reader="jmsQueueReader"
processor="messageProcessor"
writer="dbWriter"
reader-transactional-queue="true"/>
</tasklet>
</step>
</job>
<bean id="xaTransactionManager" class="org.springframework.transaction.jta.JtaTransactionManager"
lazy-init="true" depends-on="inventoryDataSource">
<constructor-arg name="transactionManager" ref="userTransactionManager"/>
<constructor-arg name="userTransaction" ref="userTransaction"/>
<property name="allowCustomIsolationLevels" value="true"/>
</bean>
<bean id="jobRepository" class="org.springframework.batch.core.repository.support.JobRepositoryFactoryBean">
<property name="dataSource" ref="batchJobsDataSource"/>
<property name="transactionManager" ref="transactionManager"/>
<property name="databaseType" value="${batch.data.source.type}"/>
</bean>
<jdbc:embedded-database id="batchJobsDataSource" type="HSQL"/>
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="batchJobsDataSource"/>
</bean>
答案 0 :(得分:0)
在单元测试和生产中的WebSphere JTA成功使用Bitronix之前,我已经在所有这3个资源中使用了XA事务。如果您从步骤的其余部分为批处理数据库提供单独的事务管理器,则在任何一个位置(批处理数据库或步骤)发生故障时,步骤和批处理数据库将面临“不同步”的风险)。
例如,您可能在步骤(JMS和DB)上成功提交,然后在批处理数据库上失败。当你重新开始工作时,它会认为某个步骤在你的基础执行时是不成功的。覆盖同一事务管理器中的所有3个资源将阻止这种情况。