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

2025-05-26 0 85

最近项目切换环境,把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内容请搜索快网idc以前的文章或继续浏览下面的相关文章希望大家以后多多支持快网idc!

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

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 关于Tomcat 结合Atomikos 实现JTA的方法 https://www.kuaiidc.com/54560.html

相关文章

发表评论
暂无评论