BTM事务配置


请参考原贴:http://thinkdifferent.iteye.com/blog/1450433



Tomcat6上配置BTM 博客分类: practice tomcatjava
1)去http://docs.codehaus.org/display/BTM/Home上下载BTMzip包。 2)解压缩包,并将如下几个jar包拷贝tomcat6的lib下:btm-2.1.1.jar,btm-tomcat55-lifecycle-2.1.1.jar,geronimo-jta_1.1_spec-1.1.1.jar,slf4j-api-1.6.1.jar,slf4j-jdk14-1.6.1.jar。 3)拷贝对应数据的jdbc驱动包到tomcat6的lib下,则这边采用oracle11g作为后端测试的数据库,所以拷贝oracle jdk6.0 jdbc包ojdbc6.jar到lib下。 4)进入tomcat6的bin目录下,编辑startup.bat,在 Java代码 收藏代码 set "EXECUTABLE=%CATALINA_HOME%incatalina.bat" 下增加一行 Java代码 收藏代码 set "CATALINA_OPTS=-Dbtm.root=%CATALINA_HOME% -Dbitronix.tm.configuration=%CATALINA_HOME%conftm-config.properties" 后,进行保存。 5)进入tomcat6的conf目录,创建文件:btm-config.properties并填入内容: Java代码 收藏代码 bitronix.tm.serverId=spring-btm bitronix.tm.journal.disk.logPart1Filename=${btm.root}/work/btm1.tlog bitronix.tm.journal.disk.logPart2Filename=${btm.root}/work/btm2.tlog bitronix.tm.resource.configuration=${btm.root}/conf/resources.properties ; 在conf目录下创建定义数据源的properties文件:resources.properties。在其中写入: Java代码 收藏代码 resource.ds1.className=oracle.jdbc.xa.client.OracleXADataSource resource.ds1.uniqueName=jdbc/oracle resource.ds1.minPoolSize=0 resource.ds1.maxPoolSize=5 resource.ds1.allowLocalTransactions=true #resource.ds1.driverProperties.driverClassName=oracle.jdbc.driver.OracleDriver resource.ds1.driverProperties.URL=jdbc:oracle:thin:@localhost:1521:orcl resource.ds1.driverProperties.user=scott resource.ds1.driverProperties.password=Pass1234 。绑定的JNDI名称为:java:comp/env/jdbc/oracle。 6)进入tomcat6的conf文件,编辑server.xml,在 Java代码 收藏代码 <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" /> 下增加一行: Java代码 收藏代码 <Listener className="bitronix.tm.integration.tomcat55.BTMLifecycleListener" /> 用于监控BTM的生命周期(在tomcat启动或者关闭时);在同一目录下,编辑context.xml文件,在 Java代码 收藏代码 <WatchedResource>WEB-INF/web.xml</WatchedResource> 下增加一行: Java代码 收藏代码 <Transaction factory="bitronix.tm.BitronixUserTransactionObjectFactory" /> 配置UserTransaction,对应的jndi名称为:java:comp/UserTransaction。在增加一行对上面配置的数据源的引用: Java代码 收藏代码 <Resource name="jdbc/oracle" auth="Container" type="javax.sql.DataSource" factory="bitronix.tm.resource.ResourceObjectFactory" uniqueName="jdbc/oracle" /> 在配置BTM的时候,发现配置了BTM管理的的数据源后,发现在Eclipse中通过tomcat的plugin来启动tomcat时,找不到配置的数据源,但在增加如上一行配置后,就能够找到了。 最后,你就可以在项目中使用如上配置的数据源及BTM的事务管理器了。
原文地址:https://www.cnblogs.com/lshan/p/9340753.html