最近项目切换环境,把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\" />
到此这篇关于Tomcat 结合Atomikos 实现JTA的文章就介绍到这了