服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

云服务器|WEB服务器|FTP服务器|邮件服务器|虚拟主机|服务器安全|DNS服务器|服务器知识|Nginx|IIS|Tomcat|

服务器之家 - 服务器技术 - Tomcat - 关于Tomcat 结合Atomikos 实现JTA的方法

关于Tomcat 结合Atomikos 实现JTA的方法

2021-11-30 15:42优优鱼 Tomcat

Tomcat作为一款经典的Web服务器,在开发、测试和生产环境中得到了广泛的使用。但Tomcat毕竟不是Java EE服务器,因此在EJB,JTA方面并没有提供支持。本文讲述了Tomcat使用Atomikos实现JTA的一种方法,需要的朋友可以参考下

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
在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中增加数据源和相关的事务管理器,下面是一个参考的例子,参数酌情修改

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
<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来关联数据源和事务管理器,参考配置如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
<!-- 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"

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
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,**

?
1
2
3
4
5
6
<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内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://www.cnblogs.com/yoyoyu/p/15590090.html

延伸 · 阅读

精彩推荐
  • TomcatTomcat日志文件定时清理备份的脚本

    Tomcat日志文件定时清理备份的脚本

    这篇文章主要介绍了Tomcat日志文件定时清理备份的脚本的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下...

    jaamy8492021-08-15
  • Tomcat解决Tomcat10 Catalina log乱码问题

    解决Tomcat10 Catalina log乱码问题

    这篇文章主要介绍了解决Tomcat10 Catalina log乱码问题,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的...

    条卯李系瓜皮10672021-09-17
  • TomcatTomcat核心组件及应用架构详解

    Tomcat核心组件及应用架构详解

    众所周知Tomcat 就是一个 Servlet 容器,为了方便使用,他们具有http服务器的功能,所以Tomcat 就是一个“HTTP 服务器 + Servlet 容器”,我们也叫它们 Web 容器,...

    PoetryAndTheDistance12612021-09-24
  • TomcatCentOS系统下安装Tomcat7的过程详解

    CentOS系统下安装Tomcat7的过程详解

    今天开始学习Tomcat7 ,学习前首先需要安装,我用的系统是CentOS系统,所以下面这篇文章主要介绍了CentOS系统下安装Tomcat7的过程,需要的朋友可以参考下,下...

    上品物语5902021-08-16
  • Tomcat如何在IntelliJ IDEA 2018上配置Tomcat并运行第一个JavaWeb项目

    如何在IntelliJ IDEA 2018上配置Tomcat并运行第一个JavaWeb项目

    这篇文章主要介绍了在IntelliJ IDEA 2018上配置Tomcat并运行第一个JavaWeb项目,需要的朋友可以参考下...

    「已注销」4242021-09-15
  • Tomcatidea打包成war包部署到tomcat及访问路径问题(图文详解)

    idea打包成war包部署到tomcat及访问路径问题(图文详解)

    这篇文章主要介绍了idea打包war包部署到tomcat以及访问路径问题,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴...

    Ma_Bu_Teng7952021-09-12
  • TomcatMac+IDEA+Tomcat配置的方法步骤

    Mac+IDEA+Tomcat配置的方法步骤

    本主要介绍了Mac+IDEA+Tomcat配置的方法步骤,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    海M滨8062021-11-14
  • Tomcattomcat的配置使用详细版(小结)

    tomcat的配置使用详细版(小结)

    开发者开发部署web应用时通常使用tomcat服务器,这篇文章主要介绍了tomcat的配置使用详细版(小结),小编觉得挺不错的,现在分享给大家,也给大家做个参...

    yumiaoxa5592021-08-31