浏览 4717 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2009-01-22
最后修改:2009-02-23
atomikos官网上没有提供DB2的配置示例,试了多次,以下配置终于搞定了全局分布式事务,见其中的注释 <tx:advice id="txAdvice" transaction-manager="txManager"> <tx:attributes> <tx:method name="get*" read-only="true" /> <tx:method name="*" rollback-for="Throwable"/> </tx:attributes> </tx:advice> <!-- 在类foo.bar.MyClass的myMethod()方法里实现全局分布式事务,该方法对两个数据源进行操作 --> <aop:config> <aop:pointcut id="myOperation" expression="execution(*foo.bar.MyClass.myMethod(..))" /> <aop:advisor advice-ref="txAdvice" pointcut-ref="myOperation" /> </aop:config> <!-- 数据源1 --> <bean id="dataSource" class="com.atomikos.jdbc.AtomikosDataSourceBean"> <property name="uniqueResourceName"> <value>app/main</value> </property> <property name="xaDataSourceClassName"> <value>[b]com.ibm.db2.jcc.DB2XADataSource[/b]</value> </property> <property name="xaProperties"> <props> [b]<prop key="serverName">172.160.1.138</prop> <prop key="portNumber">50000</prop> <prop key="databaseName">MYDB</prop> <prop key="user">db2admin</prop> <prop key="password">pass</prop> <prop key="driverType">4</prop>[/b] </props> </property> <property name="poolSize"> <value>5</value> </property> </bean> <!-- 数据源2 --> <bean id="dataSourceHis" class="com.atomikos.jdbc.AtomikosDataSourceBean"> <property name="uniqueResourceName"> <value>app/history</value> </property> <property name="xaDataSourceClassName"> <value>com.ibm.db2.jcc.DB2XADataSource</value> </property> <property name="xaProperties"> <props> <prop key="serverName">172.160.1.139</prop> <prop key="portNumber">50000</prop> <prop key="databaseName">NDB</prop> <prop key="user">db2admin</prop> <prop key="password">pass</prop> <prop key="driverType">4</prop> </props> </property> <property name="poolSize"> <value>5</value> </property> </bean> <!-- 数据源1的iBatis sqlMapClient --> <bean id="sqlMapClient1" class="org.springframework.orm.ibatis.SqlMapClientFactoryBean"> <property name="configLocation"> <value>SqlMapConfig.xml</value> </property> <property name="dataSource"> <ref bean="dataSource" /> </property> </bean> <!-- 数据源2的iBatis sqlMapClient --> <bean id="sqlMapClient2" class="org.springframework.orm.ibatis.SqlMapClientFactoryBean"> <property name="configLocation"> <value>SqlMapConfig.xml</value> </property> <property name="dataSource"> <ref bean="dataSourceHis" /> </property> </bean> <bean id="atomikosTransactionManager" class="com.atomikos.icatch.jta.UserTransactionManager" init-method="init" destroy-method="close"> <property name="forceShutdown"> <value>true</value> </property> </bean> <bean id="atomikosUserTransaction" class="com.atomikos.icatch.jta.UserTransactionImp"> <property name="transactionTimeout" value="240" /> </bean> <bean id="txManager" class="org.springframework.transaction.jta.JtaTransactionManager"> <property name="transactionManager"> <ref bean="atomikosTransactionManager" /> </property> <property name="userTransaction"> <ref bean="atomikosUserTransaction" /> </property> </bean> <-- 访问数据源1的dao --> <bean id="dao1" class="foo.bar.dao.My1DAOImpl"> <property name="sqlMapClient"> <ref bean="sqlMapClient" /> </property> </bean> <-- 访问数据源2的dao --> <bean id="dao2" class="foo.bar.dao.My2DAOImpl"> <property name="sqlMapClient"> <ref bean="sqlMapClientHis" /> </property> </bean> iBatis的配置没有特殊的地方,使用abator for iBatis自动生成,abatorConfig.xml里daoGenerator的type属性设置为'SPRING' 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2009-02-24
spring+atomikos?您有结合hibernate配置过吗
我使用的环境是hibernate5、tomcat6、mydql5.0 inneDB 但是配置好久都是抱错 null source 以前相关帖子都结贴了,哪位有经验请教一下,谢谢 |
|
返回顶楼 | |
发表时间:2009-06-01
你好,请问,能上传你的fp12版本的db2jcc.jar, 这个jar实在不好找.先谢了.
|
|
返回顶楼 | |