關於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

到此這篇關於Tomcat 結合Atomikos 實現JTA的文章就介紹到這瞭,更多相關Atomikos 實現JTA內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: