经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 软件/图像 » Atom » 查看文章
关于Tomcat?结合Atomikos?实现JTA的方法
来源:jb51  时间:2021/11/23 12:52:57  对本文有异议

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

  1. Tomcat中使用JTA,可以将Atomikos部署在Tomcat中,使用Tomcat支持的数据源;也可以在项目中配置,利用Spring配置好数据源、连接池、事务管理器等等。两种方式各有特点,本文只介绍TomcatAtomikos的集成,集成后Tomcat可以对外提供JTA的事务管理器和数据源。
  2.  
  3. 在使用Atomikos之前,我们也曾使用过JOTM,不过在高并发的情况下,JOTM频频出错,最后不得不放弃,通过测试,发现Atomikos性能和稳定性都不错。
  4.  
  5. 我们使用了Atomikos最新的4.04版本,Jar包的获取可以从maven的配置库中得到,链接地址:http://mvnrepository.com/artifact/com.atomikos
  6.  
  7. 如果不使用Hibernate,需要的包包括:
  8.  
  9. atomikos-util.jar,
  10. jta.jar,
  11. transactions.jar,
  12. transactions-api.jar,
  13. transactions-jdbc.jar,
  14. transactions-jta.jar
  15.  
  16. 集成包:
  17. atomikos-integration-extension-3.7.2.jar
  18.  
  19. 记得放数据库 驱动

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中增加数据源和相关的事务管理器,下面是一个参考的例子,参数酌情修改

  1. <Resource name="jdbc/DS_MYSQL"
  2.  
  3. auth="Container"
  4.  
  5. type="com.atomikos.jdbc.AtomikosDataSourceBean"
  6.  
  7. uniqueResourceName="jdbc/DS_MYSQL"
  8.  
  9. xaDataSourceClassName="com.mysql.jdbc.jdbc2.optional.MysqlXADataSource"
  10.  
  11. xaProperties.databaseName="db_test"
  12.  
  13. xaProperties.serverName="localhost"
  14.  
  15. xaProperties.port="3306"
  16.  
  17. xaProperties.user="root"
  18.  
  19. xaProperties.password="root"
  20.  
  21. maxPoolSize="200"
  22.  
  23. xaProperties.url="jdbc:mysql://localhost:3306/db_test?characterEncoding=UTF8"
  24.  
  25. factory="com.atomikos.tomcat.EnhancedTomcatAtomikosBeanFactory" />
  26.  
  27. <Resource name="UserTransaction"
  28.  
  29. auth="Container"
  30.  
  31. type="javax.transaction.UserTransaction" />
  32.  
  33. <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来关联数据源和事务管理器,参考配置如下:

  1. <!-- JNDI模板配置信息,用于连接应用服务器-->
  2.  
  3. <bean class="org.springframework.jndi.JndiTemplate" id="jndiTemplate" />
  4. <bean class="org.springframework.jndi.JndiObjectFactoryBean" id="dataSource">
  5.  
  6. <property name="jndiName">
  7.  
  8. <value>java:comp/env/jdbc/DS_MYSQL</value>
  9.  
  10. </property>
  11.  
  12. <property name="jndiTemplate">
  13.  
  14. <ref bean="jndiTemplate"/>
  15.  
  16. </property>
  17.  
  18. </bean>
  19.  
  20. <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
  21.  
  22. <property name="dataSource">
  23.  
  24. <ref bean="dataSource" />
  25.  
  26. </property>
  27.  
  28. </bean>
  29.  
  30. <!--用户事务对象-->
  31.  
  32. <bean class="org.springframework.jndi.JndiObjectFactoryBean" id="userTransaction">
  33.  
  34. <!--class="org.springframework.transaction.jta.WebLogicJtaTransactionManager">-->
  35.  
  36. <property name="jndiName">
  37.  
  38. <value>java:comp/UserTransaction</value>
  39.  
  40. </property>
  41.  
  42. <property name="jndiTemplate">
  43.  
  44. <ref bean="jndiTemplate"/>
  45.  
  46. </property>
  47.  
  48. </bean>
  49.  
  50. <bean id="atomikosTransactionManager" class="com.atomikos.icatch.jta.UserTransactionManager"
  51.  
  52. init-method="init" destroy-method="close">
  53.  
  54. <property name="forceShutdown" value="false" />
  55.  
  56. </bean>
  57.  
  58. <!-- 配置基于注解的声明式事务管理器 -->
  59.  
  60. <bean id="transactionManager" class="org.springframework.transaction.jta.JtaTransactionManager">
  61.  
  62. <property name="userTransaction" ref="userTransaction" />
  63.  
  64. <property name="transactionManager" ref="atomikosTransactionManager" />
  65.  
  66. </bean>
  67.  
  68. <tx:annotation-driven transaction-manager="transactionManager" />

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

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

<Resource name="jdbc/DS_MYSQL"

  1. auth="Container"
  2. type="com.atomikos.jdbc.nonxa.AtomikosNonXADataSourceBean"
  3.  
  4. uniqueResourceName="jdbc/DS_MYSQL"
  5.  
  6. driverClassName="com.mysql.jdbc.Driver"
  7.  
  8. maxPoolSize="200"
  9.  
  10. url="jdbc:mysql://localhost:3306/db_test?characterEncoding=UTF8"
  11.  
  12. user="root"
  13.  
  14. password="root"
  15.  
  16. factory="com.atomikos.tomcat.EnhancedTomcatAtomikosBeanFactory" />

**踩坑记录**

**在这里因为有事务管理 TransactionManager? 通过这个type 一直获取不到? UserTransaction? 经debug发现找取的不是这个类 **

**换成 type="com.atomikos.icatch.jta.userTransactionImp" 成功获取到 UserTransaction,**

  1. <Resource name="UserTransaction"
  2.  
  3. auth="Container"
  4. type="com.atomikos.icatch.jta.userTransactionImp"/>
  5.  
  6. <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内容请搜索w3xue以前的文章或继续浏览下面的相关文章希望大家以后多多支持w3xue!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号