两种XA的实现方式
XA是一个协议,基于2pc的思想
XA的实现方式有很多,关键是思想,而且每种分布式事务的实现都有其局限,在高并发下并不适合采用XA,下面我通过两种方式来实现XA,一种是seata的方式,一种是通过atomikos依赖的方式
seata
seata是一个中间件,实现XA很容易,关键是需要搭建seata环境,seata环境的搭建可以参照官网的demo,搭建好之后开启XA模式即可,seata的AT和XA在编程方面都比较简单
atomikos
atomikos是通过依赖来实现的,下面是我引入的依赖
<dependency>
<groupId>com.atomikos</groupId>
<artifactId>transactions-jdbc</artifactId>
<version>4.0.6</version>
</dependency>
<dependency>
<groupId>javax.transaction</groupId>
<artifactId>jta</artifactId>
<version>1.1</version>
</dependency>
引入之后需要进行一些配置
<bean id="qsDataSource" class="com.atomikos.jdbc.AtomikosDataSourceBean"
destroy-method="close">
<property name="xaDataSourceClassName" value="com.alibaba.druid.pool.xa.DruidXADataSource" />
<property name="xaProperties" >
<props>
<prop key="url" >jdbc:oracle:thin:</prop>
<prop key="username">Branc</prop>
<prop key="password">11</prop>
</props>
</property>
<property name="uniqueResourceName" value="clearing"/>
<property name="poolSize" value="3" />
<property name="minPoolSize" value="3" />
<property name="maxPoolSize" value="5" />
</bean>
<bean id="dataSource" class="com.atomikos.jdbc.AtomikosDataSourceBean"
destroy-method="close">
<property name="xaDataSourceClassName" value="com.alibaba.druid.pool.xa.DruidXADataSource" />
<property name="xaProperties" >
<props>
<prop key="url" >jdbc:oracle:thi</prop>
<prop key="username">Branch</prop>
<prop key="password">Oracl</prop>
</props>
</property>
<property name="uniqueResourceName" value="payment11111111111"/>
<property name="poolSize" value="3" />
<property name="minPoolSize" value="3" />
<property name="maxPoolSize" value="5" />
</bean>
之后配置事务管理器
<bean id="userTransaction" class="com.atomikos.icatch.jta.UserTransactionImp">
<property name="transactionTimeout" value="300" />
</bean>
<bean id="springTransactionManager" class="org.springframework.transaction.jta.JtaTransactionManager">
<property name="userTransaction" ref="userTransaction" />
</bean>
<tx:annotation-driven transaction-manager="springTransactionManager"/>
最后再需要使用事务的地方标上 @Transactional注解即可,指定成你设定的事务管理器的名称