使用spring和hibernate可以很方便的实现一个数据源的事务管理,但是如果需要同时对多个数据源进行事务控制,并且不想使用重量级容器提供的机制的话,可以使用JOTM达到目的.

JOTM的配置十分简单,spring已经内置了对JOTM的支持,
一.
<bean id="jotm" class="org.springframework.transaction.jta.JotmFactoryBean"/>
 
 <bean id="transactionManager" class="org.springframework.transaction.jta.JtaTransactionManager">
    <property name="userTransaction"><ref local="jotm"/></property>
 </bean>

首先定义如上的两个bean,利用spring对JOTM进行初始化.

二.接下来定义所需的数据源
<bean id="innerMysqlDataSource" class="org.enhydra.jdbc.standard.StandardXADataSource" destroy-method="shutdown">
<property name="transactionManager"><ref local="jotm"/></property>
<property name="driverName"><value>oracle.jdbc.driver.OracleDriver</value></property>
<property name="url"><value>jdbc:oracle:thin:@192.168.1.224:1521:speed</value></property>
</bean>

<bean id="dataSource" class="org.enhydra.jdbc.pool.StandardXAPoolDataSource" destroy-method="shutdown">
<property name="dataSource"><ref local="innerMysqlDataSource"/></property>
<property name="maxSize"><value>5</value></property>
<property name="minSize"><value>2</value></property>
<property name="user"><value>stms</value></property>
<property name="password"><value>speed</value></property>
</bean>
通过如上的两个bean定义一个数据源,所需的jar在下载的jotm的压缩包中都以自带.

三.如果还需要定义多个数据源的话,就照如上的格式定义即可.

四.定义好数据源后,我们再定义相应的sessionFactory
<bean id="mySessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
     <property name="dataSource" ref="dataSource"/>
     <property name="mappingResources">
        <list>
          <value>com/vtradex/edi/example/om/oracle/Example.hbm.xml</value>
        </list>
     </property>
     <property name="hibernateProperties">
        <props>
          <prop key="hibernate.dialect">org.hibernate.dialect.Oracle9Dialect</prop>
        </props>
     </property>
    <property name="jtaTransactionManager">
   <ref bean="jotm" />
  </property>

</bean>
mySessionFactory使用dataSource这个数据源

五.定义一个进行事务控制的代理
<bean id="abstractTransactionProxy" abstract="true"
          class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
        <property name="transactionManager">
            <ref bean="transactionManager"/>
        </property>
        <property name="transactionAttributeSource">
            <bean class="org.springframework.transaction.annotation.AnnotationTransactionAttributeSource"/>
        </property>
    </bean>

六.以上都是一些准备工作,完成后,接下来就可以对我们自己的需要进行事务控制的bean进行定义了
<bean id="hqlExecutor1" class="com.vtradex.edi.example.util.HqlExecutor" singleton="false">
     <property name="sessionFactory" ref="mySessionFactory"/>
 </bean>
<bean id="hqlExecutor2" class="com.vtradex.edi.example.util.HqlExecutor" singleton="false">
     <property name="sessionFactory" ref="mySessionFactory2"/>
 </bean>
    <bean id="tt" parent="abstractTransactionProxy">
        <property name="target">
            <bean class="com.vtradex.edi.server.service.Tt">
                    <property name="hqlExec1" ref="hqlExecutor1"/>
                    <property name="hqlExec2" ref="hqlExecutor2"/>
            </bean>
        </property>
    </bean>
hqlExecutor1使用mySessionFactory来对数据源进行操作
而hqlExecutor2使用mySessionFactory2来对数据源进行操作

tt这个bean中使用了hqlExecutor1和hqlExecutor2来进行操作.

================================================================================

看一下配置实例

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd">
<beans>
 <bean id="jotm" class="org.springframework.transaction.jta.JotmFactoryBean"/>
 
 <bean id="transactionManager" class="org.springframework.transaction.jta.JtaTransactionManager">
    <property name="userTransaction"><ref local="jotm"/></property>
 </bean>
 <bean id="innerMysqlDataSource" class="org.enhydra.jdbc.standard.StandardXADataSource" destroy-method="shutdown">
<property name="transactionManager"><ref local="jotm"/></property>
<property name="driverName"><value>oracle.jdbc.driver.OracleDriver</value></property>
<property name="url"><value>jdbc:oracle:thin:@192.168.1.224:1521:speed</value></property>
</bean>

<bean id="dataSource" class="org.enhydra.jdbc.pool.StandardXAPoolDataSource" destroy-method="shutdown">
<property name="dataSource"><ref local="innerMysqlDataSource"/></property>
<property name="maxSize"><value>5</value></property>
<property name="minSize"><value>2</value></property>
<property name="user"><value>stms</value></property>
<property name="password"><value>speed</value></property>
</bean>
 
   <bean id="mySessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
     <property name="dataSource" ref="dataSource"/>
     <property name="mappingResources">
        <list>
          <value>com/vtradex/edi/example/om/oracle/Example.hbm.xml</value>
        </list>
     </property>
     <property name="hibernateProperties">
        <props>
          <prop key="hibernate.dialect">org.hibernate.dialect.Oracle9Dialect</prop>
        </props>
     </property>
    <property name="jtaTransactionManager">
   <ref bean="jotm" />
  </property>

</bean>
  <bean id="innerMysqlDataSource2" class="org.enhydra.jdbc.standard.StandardXADataSource" destroy-method="shutdown">
<property name="transactionManager"><ref local="jotm"/></property>
<property name="driverName"><value>oracle.jdbc.driver.OracleDriver</value></property>
<property name="url"><value>jdbc:oracle:thin:@192.168.1.224:1521:speed</value></property>
</bean>

<bean id="dataSource2" class="org.enhydra.jdbc.pool.StandardXAPoolDataSource" destroy-method="shutdown">
<property name="dataSource"><ref local="innerMysqlDataSource2"/></property>
<property name="maxSize"><value>5</value></property>
<property name="minSize"><value>2</value></property>
<property name="user"><value>swms</value></property>
<property name="password"><value>speed</value></property>
</bean>
   <bean id="mySessionFactory2" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
     <property name="dataSource" ref="dataSource2"/>
     <property name="mappingResources">
        <list>
          <value>com/vtradex/edi/example/om/oracle/Message.hbm.xml</value>
        </list>
     </property>
     <property name="hibernateProperties">
        <props>
          <prop key="hibernate.dialect">org.hibernate.dialect.Oracle9Dialect</prop>
        </props>
     </property>
    <property name="jtaTransactionManager">
   <ref bean="jotm" />
  </property>

</bean>

<bean id="hqlExecutor2" class="com.vtradex.edi.example.util.HqlExecutor" singleton="false">
     <property name="sessionFactory" ref="mySessionFactory2"/>
 </bean>
 
    <bean id="abstractTransactionProxy" abstract="true"
          class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
        <property name="transactionManager">
            <ref bean="transactionManager"/>
        </property>
        <property name="transactionAttributeSource">
            <bean class="org.springframework.transaction.annotation.AnnotationTransactionAttributeSource"/>
        </property>
    </bean>
    <bean id="tt" parent="abstractTransactionProxy">
        <property name="target">
            <bean class="com.vtradex.edi.server.service.Tt">
            </bean>
        </property>
    </bean>
</beans>

使用JOTM实现分布式事务管理(多数据源)相关推荐

  1. springmvc atomikos mysql数据源_Spring多数据源分布式事务管理/springmvc+spring+atomikos[jta]+druid+mybatis...

    项目进行读写分离及分库分表,在一个业务中,在一个事务中处理时候将切换多个数据源,需要保证同一事务多个数据源数据的一致性.此处使用atomikos来实现:最后附源码: 1:spring3.0之后不再支持 ...

  2. Spring+Hibernate+Atomikos集成构建JTA的分布式事务--解决多数据源跨库事务

    一.概念 分布式事务 分布式事务是指事务的参与者.支持事务的服务器.资源服务器以及事务管理器分别位于不同的分布式系统的不同节点之上.简言之,同时操作多个数据库保持事务的统一,达到跨库事务的效果. JT ...

  3. 在Spring中使用JOTM实现JTA事务管理

    Spring 通过AOP技术可以让我们在脱离EJB的情况下享受声明式事务的丰盛大餐,脱离Java EE应用服务器使用声明式事务的道路已经畅通无阻.但是很大部分人都还认为脱离Java EE应用服务器就无 ...

  4. spring事务隔离级别、传播行为以及spring+mybatis+atomikos实现分布式事务管理

    1.事务的定义:事务是指多个操作单元组成的合集,多个单元操作是整体不可分割的,要么都操作不成功,要么都成功.其必须遵循四个原则(ACID). 原子性(Atomicity):即事务是不可分割的最小工作单 ...

  5. 解读金融高频交易不出错的金手指:分布式事务管理

    本文分享自华为云社区<华为云分布式事务管理DTM:6大特性解决云上微服数据一致性>,原文作者:灰灰哒. 云原生2.0时代,微服务架构下如何保证数据的一致性是非常重要的一个课题.4月8日,在 ...

  6. 电商千万级交易的金手指:分布式事务管理

    摘要:从古至今,我们的交易与消费过程 发生着翻天覆地的变化.今天,带大家一起 解密持续千年那些买买买背后的故事. 本文分享自华为云社区<揭秘买买买千万级交易背后的那些事>,原文作者:华为云 ...

  7. SpringBoot+Nacos+Seata实现Dubbo分布式事务管理

    SpringBoot+Nacos+Seata实现Dubbo分布式事务管理 https://www.shangmayuan.com/a/a3ba056126ba45db9b8dfd5b.html 源码下 ...

  8. SpringBoot+Zookeeper+Seata实现Dubbo分布式事务管理

    面我已经写过一篇SpringBoot+Nacos+Seata实现Dubbo分布式事务管理的文章,今天为什么还要写这篇呢,是因为好多公司还在用Zookeeper作为Dubbo的注册中心和配置中心在大规模 ...

  9. Spring-Boot + Atomikos 实现跨库的分布式事务管理

    一.何为事务 定义:事务是指多个操作单元组成的合集,多个单元操作是整体不可分割的,要么都操作成功,要么都不成功. 其必须遵循的四个原则(ACID): 原子性(Atomicity -- 美 [ˌætəˈ ...

最新文章

  1. xshell问题汇总
  2. Java程序(类的抽象与封装)
  3. 浏览器同源策略及Cookie的作用域
  4. golang web开发框架 Beego
  5. Springboot整合shiro基于url身份认证和授权认证
  6. c++中友元函数详解
  7. dataset.xsd的定义(vs2008)
  8. kafka处理大数据包
  9. 在一个字符串中找到第一个只出现一次的字符,并返回它的位置
  10. iOS---实现在屏幕上实时绘图的简单效果---CAShaperLayer和UIBezierPath的简单运用
  11. java做一个万年历和闹钟,c51实现万年历、温度与闹钟功能程序
  12. android高德地图选取坐标点,【API】高德地图API JS实现获取坐标和回显点标记(示例代码)...
  13. 优秀的思维导图怎么制作
  14. 目前国内最快最稳定的DNS
  15. python模拟ios点击_使用Xcode + Python进行IOS运动轨迹模拟
  16. 德格:一个专门为中小型企业做定制化服务的SaaS平台
  17. QCOM 8976 porting SPI device
  18. banq修复_SM3271AB_慧荣SM3271AB U盘量产加密及修复教程 - 系统部
  19. winin10怎么锁定计算机,win10系统下设置电脑固定ip地址的方法
  20. 2022焊工(高级)培训试题及答案

热门文章

  1. 搜索引擎提交软件_增加SEO超级外链须知的高权重网站目录提交方法
  2. Python函数之 ceil, floor,round
  3. hbase数据迁移到hive中
  4. MSN8.0经常出现连接错误,如何解决?
  5. Spring Boot 自动配置原理
  6. php的符号的排序大小
  7. python爬取豆瓣前25个影片内容的正则表达式练习
  8. [模板]平面最近点对
  9. Android ListView几个重要属性
  10. eclipse 与 tomcat 的那些路径