两种XA的实现方式

两种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注解即可,指定成你设定的事务管理器的名称

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

悦悦是个演员啊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值