• Tomcat 结合Atomikos 实现JTA


    最近项目切换环境,把weblogic 换成tomcat 记录中间遇到的问题
    Tomcat下配置Atomikos实现JTA
    Tomcat作为一款经典的Web服务器,在开发、测试和生产环境中得到了广泛的使用。但Tomcat毕竟不是Java EE服务器,因此在EJB,JTA方面并没有提供支持。本文讲述了Tomcat使用Atomikos实现JTA的一种方法。

    
             在Tomcat中使用JTA,可以将Atomikos部署在Tomcat中,使用Tomcat支持的数据源;也可以在项目中配置,利用Spring配置好数据源、连接池、事务管理器等等。两种方式各有特点,本文只介绍Tomcat与Atomikos的集成,集成后Tomcat可以对外提供JTA的事务管理器和数据源。
    
             在使用Atomikos之前,我们也曾使用过JOTM,不过在高并发的情况下,JOTM频频出错,最后不得不放弃,通过测试,发现Atomikos性能和稳定性都不错。
    
             我们使用了Atomikos最新的4.04版本,Jar包的获取可以从maven的配置库中得到,链接地址:http://mvnrepository.com/artifact/com.atomikos
    
    如果不使用Hibernate,需要的包包括:
    
    atomikos-util.jar,
    jta.jar,
    transactions.jar,
    transactions-api.jar,
    transactions-jdbc.jar,
    transactions-jta.jar
    
    集成包:
    atomikos-integration-extension-3.7.2.jar
    
    记得放数据库 驱动
    
    配置步骤如下:
    
    Step 1:将这些jar 拷贝到tomcat 的lib 目录中。要实现Tomcat与Atomikos集成,还需要一个集成包,这个集成包里面有两个class,可以自己参考实现,也可以使用官方提供的jar包,最新的是
    atomikos-integration-extension-3.7.2.jar
    
    Step2:在tomcat/config/server.xml中 增加一个监听器
    
     
    
      <Listener className="com.atomikos.tomcat.AtomikosLifecycleListener" />
    
    Step3:在tomcat/config/context.xml中增加数据源和相关的事务管理器,下面是一个参考的例子,参数酌情修改
    
      <Resource name="jdbc/DS_MYSQL"
    
                auth="Container"
    
                type="com.atomikos.jdbc.AtomikosDataSourceBean"
    
                uniqueResourceName="jdbc/DS_MYSQL"
    
                xaDataSourceClassName="com.mysql.jdbc.jdbc2.optional.MysqlXADataSource"
    
                xaProperties.databaseName="db_test"
    
                xaProperties.serverName="localhost"
    
                xaProperties.port="3306"
    
                xaProperties.user="root"
    
                xaProperties.password="root"
    
                maxPoolSize="200"
    
                xaProperties.url="jdbc:mysql://localhost:3306/db_test?characterEncoding=UTF8"
    
                factory="com.atomikos.tomcat.EnhancedTomcatAtomikosBeanFactory" />
    
     
    
      <Resource name="UserTransaction"
    
                auth="Container"
    
                type="javax.transaction.UserTransaction" />   
    
       <Transaction factory="com.atomikos.icatch.jta.UserTransactionFactory" /> 
    
    Step4:在tomcat/lib目录下增加一个jta.properties文件,设置Atomikos事务相关的参数,否则将使用默认的配置参数,一些并发事务数(默认50个),超时时间等都需要调整,下面给出了文件中的一些参数配置,参数解释请查阅官方文档:https://www.atomikos.com/Documentation/JtaProperties
    添加此行配置
    com.atomikos.icatch.service=com.atomikos.icatch.standalone.UserTransactionServiceFactory
     
    
     Atomikos中参数的默认值在transactions.jar中定义,transactions-default.properties:有兴趣的可以自己去看
     
    
         配置完以上四个步骤,Tomcat的集成就算完成了,项目中可以使用Spring来关联数据源和事务管理器,参考配置如下:
    
     <!-- JNDI模板配置信息,用于连接应用服务器-->
    
    <bean class="org.springframework.jndi.JndiTemplate" id="jndiTemplate" />
    
    <bean class="org.springframework.jndi.JndiObjectFactoryBean" id="dataSource">
    
        <property name="jndiName">
    
            <value>java:comp/env/jdbc/DS_MYSQL</value>
    
        </property>
    
        <property name="jndiTemplate">
    
            <ref bean="jndiTemplate"/>
    
        </property>
    
    </bean>
    
    
    
    <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
    
        <property name="dataSource">
    
            <ref bean="dataSource" />
    
        </property>
    
    </bean>  
    
    
    
    <!--用户事务对象-->
    
    <bean class="org.springframework.jndi.JndiObjectFactoryBean" id="userTransaction">
    
        <!--class="org.springframework.transaction.jta.WebLogicJtaTransactionManager">-->
    
        <property name="jndiName">
    
            <value>java:comp/UserTransaction</value>
    
        </property>
    
        <property name="jndiTemplate">
    
            <ref bean="jndiTemplate"/>
    
        </property>
    
    </bean>
    
    
    
    <bean id="atomikosTransactionManager" class="com.atomikos.icatch.jta.UserTransactionManager"
    
        init-method="init" destroy-method="close">
    
        <property name="forceShutdown" value="false" />
    
    </bean>
    
    <!-- 配置基于注解的声明式事务管理器 -->
    
    <bean id="transactionManager" class="org.springframework.transaction.jta.JtaTransactionManager">
    
        <property name="userTransaction" ref="userTransaction" />
    
        <property name="transactionManager" ref="atomikosTransactionManager" />
    
    </bean> 
    
    
    
    
    
    <tx:annotation-driven transaction-manager="transactionManager" />
    
     
    

    以下是我项目中使用的配置:推荐在 conf.xml中配置

    在Tomcat配置中使用的XA的数据源和JDBC驱动,可以使用nonXA的相关设置,Atomikos中也支持非XA的连接,以提高运行速度。关于nonXa的数据源,可以参考一下配置:
    

    <Resource name="jdbc/DS_MYSQL"

            auth="Container"
    
            type="com.atomikos.jdbc.nonxa.AtomikosNonXADataSourceBean"
    
            uniqueResourceName="jdbc/DS_MYSQL"
    
            driverClassName="com.mysql.jdbc.Driver"
    
            maxPoolSize="200"
    
            url="jdbc:mysql://localhost:3306/db_test?characterEncoding=UTF8"
    
            user="root"
    
            password="root"
    
            factory="com.atomikos.tomcat.EnhancedTomcatAtomikosBeanFactory" /> 
    


    
    
    **踩坑记录**
    **在这里因为有事务管理 TransactionManager  通过这个type 一直获取不到  UserTransaction  经debug发现找取的不是这个类 **
    **换成 type="com.atomikos.icatch.jta.userTransactionImp" 成功获取到 UserTransaction,**
      <Resource name="UserTransaction"
                auth="Container"
                type="com.atomikos.icatch.jta.userTransactionImp"/>   
       <Transaction factory="com.atomikos.icatch.jta.UserTransactionFactory" /> 
    
    
    `
    
    https://blog.csdn.net/xuyu_yt/article/details/77905553?locationNum=14%20fps=1
  • 相关阅读:
    前端工程化之动态数据代理
    webapp开发之需要知道的css细节
    html-webpack-plugin详解
    file-loader引起的html-webpack-plugin坑
    浅谈react受控组件与非受控组件
    React创建组件的三种方式及其区别
    react项目开发中遇到的问题
    css伪元素:before和:after用法详解
    python之文件操作
    python之range和xrange
  • 原文地址:https://www.cnblogs.com/yoyoyu/p/15590090.html
Copyright © 2020-2023  润新知