zoukankan      html  css  js  c++  java
  • Spring-事物-不依赖应用服务器的开源JTA事物实现

    不依赖应用服务器的开源JTA事物实现JOTM和Atomikos Transactions

    JOTM
        即基于Java开放事务管理器(Java Open Transaction Manager),实现JTA规范,能够运行在非应用服务器环境中,Web容器或独立Java SE环境,官网地址: http://jotm.objectweb.org/。
    Atomikos Transactions Essentials 其为Atomikos开发的事务管理器,该产品属于开源产品,另外还一个商业的Extreme Transactions。官网地址为:http://www.atomikos.com。

      在本文中将使用Atomikos Transactions Essentials来进行演示JTA事务使用,由于Atomikos对hsqldb分布式支持不是很好,在Atomikos官网中列出如下兼容的数据库:Oracle、Informix、FirstSQL、DB2、MySQL、SQLServer、Sybase,这不代表其他数据库不支持,而是Atomikos团队没完全测试,在此作者决定使用derby内存数据库来演示JTA分布式事务。

    1、首先准备jar包:

    1.1、准备derby数据jar包,到下载的spring-framework-3.0.5.RELEASE-dependencies.zip中拷贝如下jar包:

    com.springsource.org.apache.derby-10.5.1000001.764942.jar


    1
    2、准备Atomikos Transactions Essentials JTA事务支持的JTA包,此处使用AtomikosTransactionsEssentials3.5.5版本,到官网下载AtomikosTransactionsEssentials-3.5.5.zip,拷贝如下jar包到类路径: 

      atomikos-util.jar
    
      transactions-api.jar
    
      transactions-essentials-all.jar
    
      transactions-jdbc.jar
    
      transactions-jta.jar
    
      transactions.jar

    将如上jar包放在libatomikos目录下,并添加到类路径中。

    2、接下来看一下在Spring中如何配置AtomikosTransactionsEssentials JTA事务:

    2.1、配置分布式数据源: 

      
    <bean id="dataSource1" class="com.atomikos.jdbc.AtomikosDataSourceBean" init-method="init" destroy-method="close">
        <property name="uniqueResourceName" value="jdbc/test1"/>
        <property name="xaDataSourceClassName" value="org.apache.derby.jdbc.EmbeddedXADataSource"/>
        <property name="poolSize" value="5"/>
        <property name="xaProperties">
            <props>
                <prop key="databaseName">test1</prop>
                <prop key="createDatabase">create</prop>
            </props>
        </property>
    </bean>
     
    <bean id="dataSource2" class="com.atomikos.jdbc.AtomikosDataSourceBean"
           init-method="init" destroy-method="close">
        ……
    </bean>

       在此我们配置两个分布式数据源:使用com.atomikos.jdbc.AtomikosDataSourceBean来配置AtomikosTransactionsEssentials分布式数据源:

    • uniqueResourceName表示唯一资源名,如有多个数据源不可重复;
    • xaDataSourceClassName是具体分布式数据源厂商实现;
    • poolSize是数据连接池大小;
    • xaProperties属性指定具体厂商数据库属性,如databaseName指定数据库名,createDatabase表示启动derby内嵌数据库时创建databaseName指定的数据库。

      在此我们还有定义了一个“dataSource2”Bean,其属性和“DataSource1”除以下不一样其他完全一样:

    • uniqueResourceName:因为不能重复,因此此处使用jdbc/test2;
    • databaseName:我们需要指定两个数据库,因此此处我们指定为test2。

    2.2、配置事务管理器:

    <bean id="atomikosTransactionManager" class = "com.atomikos.icatch.jta.UserTransactionManager" init-method="init" destroy-method = "close">  
          <property name="forceShutdown" value="true"/>  
    </bean>  
    <bean id="atomikosUserTransaction" class="com.atomikos.icatch.jta.UserTransactionImp">  </bean>  
     
    <bean id="transactionManager" class="org.springframework.transaction.jta.JtaTransactionManager">  
        <property name="transactionManager">  
            <ref bean="atomikosTransactionManager"/>  
        </property>  
        <property name="userTransaction">  
            <ref bean="atomikosUserTransaction"/>  
        </property>  
    </bean>   
     
    • atomikosTransactionManager:定义了AtomikosTransactionsEssentials事务管理器;
    • atomikosUserTransaction:定义UserTransaction,该Bean是线程安全的;
    • transactionManager:定义Spring事务管理器,transactionManager属性指定外部事务管理器(真正的事务管理者),使用userTransaction指定UserTransaction,该属性一般用于本地JTA实现,如果使用应用服务器事务管理器,该属性将自动从JNDI获取。

    配置完毕,是不是也挺简单的,但是如果确实需要使用JTA事务,请首先选择应用服务器事务管理器,本示例不适合生产环境,如果非要运用到生产环境,可以考虑购买AtomikosTransactionsEssentials商业支持。

      b)特定服务器事务管理器

      Spring还提供了对特定应用服务器事务管理器集成的支持,目前提供对IBM WebSphere、BEA WebLogic、 Oracle OC4J应用服务器高级事务的支持,具体使用请参考Spring Javadoc。

        现在我们已经学习如何配置事务管理器了,但是只有事务管理器Spring能自动进行事务管理吗?当然不能了,这需要我们来控制,目前Spring支持两种事务管理方式:编程式和声明式事务管理。接下来先看一下如何进行编程式事务管理吧。

  • 相关阅读:
    Android Architecture Components
    adb命令
    Dagger2 scope
    Dagger2学习资源
    Dependency Injection学习笔记
    什么是ADB
    使用AndroidStudio dump heap,再用 Eclipse MAT插件分析内存泄露
    Dagger学习笔记
    linux & shell & nginx & Docker Kubernetes
    Go 目录
  • 原文地址:https://www.cnblogs.com/hwaggLee/p/4439377.html
Copyright © 2011-2022 走看看