關(guān)于Tomcat?結(jié)合Atomikos?實現(xiàn)JTA的方法
最近項目切換環(huán)境,把weblogic 換成tomcat 記錄中間遇到的問題
Tomcat下配置Atomikos實現(xiàn)JTA
Tomcat作為一款經(jīng)典的Web服務(wù)器,在開發(fā)、測試和生產(chǎn)環(huán)境中得到了廣泛的使用。但Tomcat畢竟不是Java EE服務(wù)器,因此在EJB,JTA方面并沒有提供支持。本文講述了Tomcat使用Atomikos實現(xiàn)JTA的一種方法。
在Tomcat中使用JTA,可以將Atomikos部署在Tomcat中,使用Tomcat支持的數(shù)據(jù)源;也可以在項目中配置,利用Spring配置好數(shù)據(jù)源、連接池、事務(wù)管理器等等。兩種方式各有特點,本文只介紹Tomcat與Atomikos的集成,集成后Tomcat可以對外提供JTA的事務(wù)管理器和數(shù)據(jù)源。
在使用Atomikos之前,我們也曾使用過JOTM,不過在高并發(fā)的情況下,JOTM頻頻出錯,最后不得不放棄,通過測試,發(fā)現(xiàn)Atomikos性能和穩(wěn)定性都不錯。
我們使用了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
記得放數(shù)據(jù)庫 驅(qū)動
Step 1:將這些jar 拷貝到tomcat 的lib 目錄中。要實現(xiàn)Tomcat與Atomikos集成,還需要一個集成包,這個集成包里面有兩個class,可以自己參考實現(xiàn),也可以使用官方提供的jar包,最新的是
atomikos-integration-extension-3.7.2.jar
Step2:在tomcat/config/server.xml中 增加一個監(jiān)聽器
? <Listener className="com.atomikos.tomcat.AtomikosLifecycleListener" />
Step3:在tomcat/config/context.xml中增加數(shù)據(jù)源和相關(guān)的事務(wù)管理器,下面是一個參考的例子,參數(shù)酌情修改
<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文件,設(shè)置Atomikos事務(wù)相關(guān)的參數(shù),否則將使用默認(rèn)的配置參數(shù),一些并發(fā)事務(wù)數(shù)(默認(rèn)50個),超時時間等都需要調(diào)整,下面給出了文件中的一些參數(shù)配置,參數(shù)解釋請查閱官方文檔:https://www.atomikos.com/Documentation/JtaProperties
添加此行配置
com.atomikos.icatch.service=com.atomikos.icatch.standalone.UserTransactionServiceFactory
?Atomikos中參數(shù)的默認(rèn)值在transactions.jar中定義,transactions-default.properties:有興趣的可以自己去看
? ? ?配置完以上四個步驟,Tomcat的集成就算完成了,項目中可以使用Spring來關(guān)聯(lián)數(shù)據(jù)源和事務(wù)管理器,參考配置如下:
<!-- JNDI模板配置信息,用于連接應(yīng)用服務(wù)器-->
<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>
<!--用戶事務(wù)對象-->
<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>
<!-- 配置基于注解的聲明式事務(wù)管理器 -->
<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的數(shù)據(jù)源和JDBC驅(qū)動,可以使用nonXA的相關(guān)設(shè)置,Atomikos中也支持非XA的連接,以提高運行速度。關(guān)于nonXa的數(shù)據(jù)源,可以參考一下配置:<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" />
**踩坑記錄**
**在這里因為有事務(wù)管理 TransactionManager? 通過這個type 一直獲取不到? UserTransaction? 經(jīng)debug發(fā)現(xiàn)找取的不是這個類 **
**換成 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
到此這篇關(guān)于Tomcat 結(jié)合Atomikos 實現(xiàn)JTA的文章就介紹到這了,更多相關(guān)Atomikos 實現(xiàn)JTA內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用tomcat設(shè)定shared lib共享同樣的jar
這篇文章主要介紹了使用tomcat設(shè)定shared lib共享同樣的jar操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-07-07
tomcat使用問題之安裝后無法訪問localhost:8080解決
當(dāng)Tomcat無法訪問localhost:8080時,可能是由于未啟動、環(huán)境變量未配置、端口號占用或版本問題,這篇文章主要介紹了tomcat使用問題之安裝后無法訪問localhost:8080解決的相關(guān)資料,需要的朋友可以參考下2024-10-10
IDEA2020.1.2創(chuàng)建web項目配置Tomcat的詳細教程
這篇文章主要介紹了IDEA2020.1.2創(chuàng)建web項目配置Tomcat的詳細教程,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-09-09
怎么減少本地調(diào)試tomcat重啟次數(shù)你知道嗎
這篇文章主要為大家詳細介紹了怎么減少本地調(diào)試tomcat重啟次數(shù),使用Groovy,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-01-01
tomcat 6.0.20在一個機器上安裝多個服務(wù)的方法
當(dāng)前前提是你已經(jīng)可以同時運行他們了,他們的端口不能相同,這里只是解釋如何把它們做成服務(wù)2009-08-08

