`
jinnianshilongnian
  • 浏览: 21544226 次
  • 性别: Icon_minigender_1
博客专栏
5c8dac6a-21dc-3466-8abb-057664ab39c7
跟我学spring3
浏览量:2425921
D659df3e-4ad7-3b12-8b9a-1e94abd75ac3
Spring杂谈
浏览量:3015002
43989fe4-8b6b-3109-aaec-379d27dd4090
跟开涛学SpringMVC...
浏览量:5644562
1df97887-a9e1-3328-b6da-091f51f886a1
Servlet3.1规范翻...
浏览量:261188
4f347843-a078-36c1-977f-797c7fc123fc
springmvc杂谈
浏览量:1599620
22722232-95c1-34f2-b8e1-d059493d3d98
hibernate杂谈
浏览量:250916
45b32b6f-7468-3077-be40-00a5853c9a48
跟我学Shiro
浏览量:5866180
Group-logo
跟我学Nginx+Lua开...
浏览量:703978
5041f67a-12b2-30ba-814d-b55f466529d5
亿级流量网站架构核心技术
浏览量:788330
社区版块
存档分类
最新评论

【第九章】 Spring的事务 之 9.2 事务管理器 ——跟我学spring3

阅读更多

9.2.1  概述

       Spring框架支持事务管理的核心是事务管理器抽象,对于不同的数据访问框架(如Hibernate)通过实现策略接口PlatformTransactionManager,从而能支持各种数据访问框架的事务管理,PlatformTransactionManager接口定义如下:

 

java代码:
public interface PlatformTransactionManager {
       TransactionStatus getTransaction(TransactionDefinition definition) throws TransactionException;
       void commit(TransactionStatus status) throws TransactionException;
       void rollback(TransactionStatus status) throws TransactionException;
}
  • getTransaction()返回一个已经激活的事务或创建一个新的事务(根据给定的TransactionDefinition类型参数定义的事务属性),返回的是TransactionStatus对象代表了当前事务的状态,其中该方法抛出TransactionException(未检查异常)表示事务由于某种原因失败。
  • commit()用于提交TransactionStatus参数代表的事务,具体语义请参考Spring Javadoc;
  • rollback()用于回滚TransactionStatus参数代表的事务,具体语义请参考Spring Javadoc。

 

TransactionDefinition接口定义如下:

 

java代码:
public interface TransactionDefinition {
       int getPropagationBehavior();
       int getIsolationLevel();
       int getTimeout();
       boolean isReadOnly();
       String getName();
}
  • getPropagationBehavior()返回定义的事务传播行为;
  • getIsolationLevel()返回定义的事务隔离级别;
  • getTimeout()返回定义的事务超时时间;
  • isReadOnly()返回定义的事务是否是只读的;
  • getName()返回定义的事务名字。

 

TransactionStatus接口定义如下:

 

java代码:
public interface TransactionStatus extends SavepointManager {
       boolean isNewTransaction();
       boolean hasSavepoint();
       void setRollbackOnly();
       boolean isRollbackOnly();
       void flush();
       boolean isCompleted();
}
  • isNewTransaction():返回当前事务状态是否是新事务
  • hasSavepoint():返回当前事务是否有保存点
  • setRollbackOnly()设置当前事务应该回滚;
  • isRollbackOnly(()返回当前事务是否应该回滚;
  • flush()用于刷新底层会话中的修改到数据库,一般用于刷新如Hibernate/JPA的会话,可能对如JDBC类型的事务无任何影响;
  • isCompleted():当前事务否已经完成。

 

9.2.2    内置事务管理器实现

Spring提供了许多内置事务管理器实现:

  • DataSourceTransactionManager位于org.springframework.jdbc.datasource包中,数据源事务管理器,提供对单个javax.sql.DataSource事务管理,用于Spring JDBC抽象框架、iBATIS或MyBatis框架的事务管理;
  • JdoTransactionManager位于org.springframework.orm.jdo包中,提供对单个javax.jdo.PersistenceManagerFactory事务管理,用于集成JDO框架时的事务管理;
  • JpaTransactionManager位于org.springframework.orm.jpa包中,提供对单个javax.persistence.EntityManagerFactory事务支持,用于集成JPA实现框架时的事务管理;
  • HibernateTransactionManager位于org.springframework.orm.hibernate3包中,提供对单个org.hibernate.SessionFactory事务支持,用于集成Hibernate框架时的事务管理;该事务管理器只支持Hibernate3+版本,且Spring3.0+版本只支持Hibernate 3.2+版本;
  • JtaTransactionManager位于org.springframework.transaction.jta包中,提供对分布式事务管理的支持,并将事务管理委托给Java EE应用服务器事务管理器;
  • OC4JjtaTransactionManager位于org.springframework.transaction.jta包中,Spring提供的对OC4J10.1.3+应用服务器事务管理器的适配器,此适配器用于对应用服务器提供的高级事务的支持;
  • WebSphereUowTransactionManager位于org.springframework.transaction.jta包中,Spring提供的对WebSphere 6.0+应用服务器事务管理器的适配器,此适配器用于对应用服务器提供的高级事务的支持;
  • WebLogicJtaTransactionManager位于org.springframework.transaction.jta包中,Spring提供的对WebLogic 8.1+应用服务器事务管理器的适配器,此适配器用于对应用服务器提供的高级事务的支持。

Spring不仅提供这些事务管理器,还提供对如JMS事务管理的管理器等,Spring提供一致的事务抽象如图9-1所示。


图9-1 Spring事务管理器

 

       接下来让我们学习一下如何在Spring配置文件中定义事务管理器:

 

一、声明对本地事务的支持:

a)JDBC及iBATIS、MyBatis框架事务管理器

 

java代码:
<bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    <property name="dataSource" ref="dataSource"/>
</bean>

 

通过dataSource属性指定需要事务管理的单个javax.sql.DataSource对象。

b)Jdo事务管理器

 

java代码:
<bean id="txManager" class="org.springframework.orm.jdo.JdoTransactionManager">
    <property name="persistenceManagerFactory" ref="persistenceManagerFactory"/>
</bean>

 

通过persistenceManagerFactory属性指定需要事务管理的javax.jdo.PersistenceManagerFactory对象。

 

c)Jpa事务管理器

 

java代码:
<bean id="txManager" class="org.springframework.orm.jpa.JpaTransactionManager">
    <property name="entityManagerFactory" ref="entityManagerFactory"/>
</bean>

 

通过entityManagerFactory属性指定需要事务管理的javax.persistence.EntityManagerFactory对象。

还需要为entityManagerFactory对象指定jpaDialect属性,该属性所对应的对象指定了如何获取连接对象、开启事务、关闭事务等事务管理相关的行为。

 

java代码:
<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
        ……
        <property name="jpaDialect" ref="jpaDialect"/>
</bean>
<bean id="jpaDialect" class="org.springframework.orm.jpa.vendor.HibernateJpaDialect"/>

 

 

d)Hibernate事务管理器

 

java代码:
<bean id="txManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
    <property name="sessionFactory" ref="sessionFactory"/>
</bean>

通过entityManagerFactory属性指定需要事务管理的org.hibernate.SessionFactory对象。

 

 

二、Spring对全局事务的支持:

 

a)Jta事务管理器

 

 

java代码:
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:jee="http://www.springframework.org/schema/jee"
    xsi:schemaLocation="
       http://www.springframework.org/schema/beans
       http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
       http://www.springframework.org/schema/jee
       http://www.springframework.org/schema/jee/spring-jee-3.0.xsd">
 
  <jee:jndi-lookup id="dataSource" jndi-name="jdbc/test"/>
  <bean id="txManager" class="org.springframework.transaction.jta.JtaTransactionManager">
    <property name="transactionManagerName" value=" java:comp/TransactionManager"/>
  </bean>
</beans>

 

“dataSource”Bean表示从JNDI中获取的数据源,而txManager是JTA事务管理器,其中属性transactionManagerName指定了JTA事务管理器的JNDI名字,从而将事务管理委托给该事务管理器。

 

这只是最简单的配置方式,更复杂的形式请参考Spring Javadoc。

 

在此我们再介绍两个不依赖于应用服务器的开源JTA事务实现:JOTM和Atomikos Transactions Essentials。

  • JOTM即基于Java开放事务管理器(Java Open Transaction Manager),实现JTA规范,能够运行在非应用服务器环境中,Web容器或独立Java SE环境,官网地址: http://jotm.objectweb.org/。
  • Atomikos Transactions Essentials其为Atomikos开发的事务管理器,该产品属于开源产品,另外还一个商业的Extreme Transactions。官网地址为:http://www.atomikos.com。

对于以上JTA事务管理器使用,本文作者只是做演示使用,如果在实际项目中需要不依赖于应用服务器的JTA事务支持,需详细测试并选择合适的。

 

在本文中将使用Atomikos Transactions Essentials来进行演示JTA事务使用,由于Atomikos对hsqldb分布式支持不是很好,在Atomikos官网中列出如下兼容的数据库:Oracle、Informix、FirstSQL、DB2、MySQL、SQLServer、Sybase,这不代表其他数据库不支持,而是Atomikos团队没完全测试,在此作者决定使用derby内存数据库来演示JTA分布式事务。

 

1、首先准备jar包:

 

1.1、准备derby数据jar包,到下载的spring-framework-3.0.5.RELEASE-dependencies.zip中拷贝如下jar包:

 

com.springsource.org.apache.derby-10.5.1000001.764942.jar

 

12、准备Atomikos Transactions Essentials JTA事务支持的JTA包,此处使用AtomikosTransactionsEssentials3.5.5版本,到官网下载AtomikosTransactionsEssentials-3.5.5.zip,拷贝如下jar包到类路径:

 

  atomikos-util.jar

  transactions-api.jar

  transactions-essentials-all.jar

  transactions-jdbc.jar

  transactions-jta.jar

  transactions.jar

将如上jar包放在lib\atomikos目录下,并添加到类路径中。

 

2、接下来看一下在Spring中如何配置AtomikosTransactionsEssentials JTA事务:

2.1、配置分布式数据源:

 

java代码:
	
<bean id="dataSource1" class="com.atomikos.jdbc.AtomikosDataSourceBean" init-method="init" destroy-method="close">
    <property name="uniqueResourceName" value="jdbc/test1"/>
    <property name="xaDataSourceClassName" value="org.apache.derby.jdbc.EmbeddedXADataSource"/>
    <property name="poolSize" value="5"/>
    <property name="xaProperties">
        <props>
            <prop key="databaseName">test1</prop>
            <prop key="createDatabase">create</prop>
        </props>
    </property>
</bean>
 
<bean id="dataSource2" class="com.atomikos.jdbc.AtomikosDataSourceBean"
       init-method="init" destroy-method="close">
    ……
</bean>

     在此我们配置两个分布式数据源:使用com.atomikos.jdbc.AtomikosDataSourceBean来配置AtomikosTransactionsEssentials分布式数据源:

  • uniqueResourceName表示唯一资源名,如有多个数据源不可重复;
  • xaDataSourceClassName是具体分布式数据源厂商实现;
  • poolSize是数据连接池大小;
  • xaProperties属性指定具体厂商数据库属性,如databaseName指定数据库名,createDatabase表示启动derby内嵌数据库时创建databaseName指定的数据库。

 

在此我们还有定义了一个“dataSource2”Bean,其属性和“DataSource1”除以下不一样其他完全一样:

  • uniqueResourceName:因为不能重复,因此此处使用jdbc/test2;
  • databaseName:我们需要指定两个数据库,因此此处我们指定为test2。

 

2.2、配置事务管理器:

 

java代码:
<bean id="atomikosTransactionManager" class = "com.atomikos.icatch.jta.UserTransactionManager" init-method="init" destroy-method = "close">  
      <property name="forceShutdown" value="true"/>  
</bean>  
<bean id="atomikosUserTransaction" class="com.atomikos.icatch.jta.UserTransactionImp">  </bean>  
 
<bean id="transactionManager" class="org.springframework.transaction.jta.JtaTransactionManager">  
    <property name="transactionManager">  
        <ref bean="atomikosTransactionManager"/>  
    </property>  
    <property name="userTransaction">  
        <ref bean="atomikosUserTransaction"/>  
    </property>  
</bean>   
 
  • atomikosTransactionManager:定义了AtomikosTransactionsEssentials事务管理器;
  • atomikosUserTransaction:定义UserTransaction,该Bean是线程安全的;
  • transactionManager:定义Spring事务管理器,transactionManager属性指定外部事务管理器(真正的事务管理者),使用userTransaction指定UserTransaction,该属性一般用于本地JTA实现,如果使用应用服务器事务管理器,该属性将自动从JNDI获取。

配置完毕,是不是也挺简单的,但是如果确实需要使用JTA事务,请首先选择应用服务器事务管理器,本示例不适合生产环境,如果非要运用到生产环境,可以考虑购买AtomikosTransactionsEssentials商业支持。

 

b)特定服务器事务管理器

Spring还提供了对特定应用服务器事务管理器集成的支持,目前提供对IBM WebSphere、BEA WebLogic、 Oracle OC4J应用服务器高级事务的支持,具体使用请参考Spring Javadoc。

 

 

现在我们已经学习如何配置事务管理器了,但是只有事务管理器Spring能自动进行事务管理吗?当然不能了,这需要我们来控制,目前Spring支持两种事务管理方式:编程式和声明式事务管理。接下来先看一下如何进行编程式事务管理吧。

 

原创内容,转载请注明出处【http://sishuok.com/forum/blogPost/list/0/2503.html

 

33
7
分享到:
评论
14 楼 winnerbee 2016-11-04  
[i][i]
引用
引用
[img][img][flash=200,200][flash=200,200]
[flash=200,200][flash=200,200][flash=200,200][url][img][list]
[*][list]
[*][*][list]
[*][*][*][list]
[*][*][*][*][list]
[*][*][*][*][*][list]
[*][*][*][*][*][*][list]
[*][*][*][*][*][*][*][list]
[*][*][*][*][*][*][*][*][list]
[*][*][*][*][*][*][*][*][*][list]
[*][*][*][*][*][*][*][*][*][*][list]
[*][*][*][*][*][*][*][*][*][*][*][list]
[*][*][*][*][*][*][*][*][*][*][*][*][list]
[*][*][*][*][*][*][*][*][*][*][*][*][*][list]
[*][*][*][*][*][*][*][*][*][*][*][*][*][*][list]
[*][*][*][*][*][*][*][*][*][*][*][*][*][*][*][list]
[*][*][*][*][*][*][*][*][*][*][*][*][*][*][*][*][list]
[*][*][*][*][*][*][*][*][*][*][*][*][*][*][*][*][*][img][list]
[*][*][*][*][*][*][*][*][*][*][*][*][*][*][*][*][*][*]
引用
[u][i][b]123123[/b][/i][/u]
  • [*][*][*][*][*][*][*][*][*][*][*][*][*][*][*][*][/list][/img]
  • [*][*][*][*][*][*][*][*][*][*][*][*][*][*][*][*][/list]
    [*][*][*][*][*][*][*][*][*][*][*][*][*][*][*][/list]
    [*][*][*][*][*][*][*][*][*][*][*][*][*][*][/list]
    [*][*][*][*][*][*][*][*][*][*][*][*][*][/list]
    [*][*][*][*][*][*][*][*][*][*][*][*][/list]
    [*][*][*][*][*][*][*][*][*][*][*][/list]
    [*][*][*][*][*][*][*][*][*][*][/list]
    [*][*][*][*][*][*][*][*][*][/list]
    [*][*][*][*][*][*][*][*][/list]
    [*][*][*][*][*][*][*][/list]
    [*][*][*][*][*][*][/list]
    [*][*][*][*][*][/list]
    [*][*][*][*][/list]
    [*][*][*][/list]
    [*][*][/list]
    [*][/list]
    [/list][/img][/url][/flash][/flash][/flash]
    |||||||||||||||||||||||||||||||||||||||||||||||||||
    |||||||||||||||||||||||||
    ||||||||||||||||||||||||
    ||||||||||||||||||||||||
    |||||||||||||||||||||||
    |||||||||||||||||||||||
    ||||||||||||||||||||||
    ||||||||||||||||||||||
    |||||||||||||||||||||
    |||||||||||||||||||||
    ||||||||||||||||||||
    ||||||||||||||||||||
    |||||||||||||||||||
    |||||||||||||||||||
    ||||||||||||||||||
    ||||||||||||||||||
    |||||||||||||||||
    |||||||||||||||||
    ||||||||||||||||
    ||||||||||||||||
    |||||||||||||||
    |||||||||||||||
    ||||||||||||||
    ||||||||||||||
    |||||||||||||
    |||||||||||||
    ||||||||||||
    ||||||||||||
    |||||||||||
    |||||||||||
    ||||||||||
    ||||||||||
    |||||||||
    |||||||||
    ||||||||
    ||||||||
    |||||||
    |||||||
    ||||||
    ||||||
    |||||
    |||||
    ||||
    ||||
    |||
    |||
    ||
    [/flash][/flash][/img][/img]
    [/i][/i]||
    |
    |
    13 楼 jybzjf 2015-07-12  
    我用Atomikos开启了事务,在spring中使用@PersistenceContext注入的EntityManager,使用这个em.persist(entity),从日志来看,事务也开启了,也提交了,就是数据没有写到DB中去。楼主知道为何吗?MYsql的DB。
    12 楼 穿围裙的程序员 2015-04-21  
    AtomikosDataSourceBean是个什么概念?XA数据源的代理么?
    EmbeddedXADataSource不是一个XA协议的数据源么?
    11 楼 heipacker 2014-03-31  
    决定使用atomikos,没一个人说为什么使用它,你们公司就这么随便就决定使用哪个哪个东西?
    10 楼 stevenjohn 2014-01-12  
    jinnianshilongnian 写道
    stevenjohn 写道
    开涛,你这里有两个dataSource,是不是意味着,还必须要两个sessionFactory呢,你这里代码没有显示出来,然后再把sessionFactory注入到了transactionManager,那么这个时候transactionManager是不是只有一个,就是那个JTA的?

    是的 这个属于分布式事务



    谢谢了,呵呵
    9 楼 jinnianshilongnian 2014-01-11  
    stevenjohn 写道
    开涛,你这里有两个dataSource,是不是意味着,还必须要两个sessionFactory呢,你这里代码没有显示出来,然后再把sessionFactory注入到了transactionManager,那么这个时候transactionManager是不是只有一个,就是那个JTA的?

    是的 这个属于分布式事务
    8 楼 stevenjohn 2014-01-10  
    开涛,你这里有两个dataSource,是不是意味着,还必须要两个sessionFactory呢,你这里代码没有显示出来,然后再把sessionFactory注入到了transactionManager,那么这个时候transactionManager是不是只有一个,就是那个JTA的?
    7 楼 縌流而上的魚 2012-11-02  
    jinnianshilongnian 写道
    縌流而上的魚 写道
    引用

    二、Spring对全局事务的支持:

    a)Jta事务管理器


    这里所讲解的例子

    引用

    但是如果确实需要使用JTA事务,请首先选择应用服务器事务管理器,本示例不适合生产环境,如果非要运用到生产环境,可以考虑购买AtomikosTransactionsEssentials商业支持。


    以及例子讲解完毕后的这句话,是否可以理解为:
    JTA事务的适用,首选应用服务器的事务管理器来管理,而不应该在自己的项目中“显示”的去定义使用他?

    还是搞的不是很明白,讲解这一章的目的在哪里?学习的目的就是为了在平时的工作和项目中用到,如果应用不到的话,或者不推荐使用的话,如果可以希望楼主能够在文章中体现出来。谢谢拉~~受益匪浅~

    这是y
    縌流而上的魚 写道
    引用

    二、Spring对全局事务的支持:

    a)Jta事务管理器


    这里所讲解的例子

    引用

    但是如果确实需要使用JTA事务,请首先选择应用服务器事务管理器,本示例不适合生产环境,如果非要运用到生产环境,可以考虑购买AtomikosTransactionsEssentials商业支持。


    以及例子讲解完毕后的这句话,是否可以理解为:
    JTA事务的适用,首选应用服务器的事务管理器来管理,而不应该在自己的项目中“显示”的去定义使用他?

    还是搞的不是很明白,讲解这一章的目的在哪里?学习的目的就是为了在平时的工作和项目中用到,如果应用不到的话,或者不推荐使用的话,如果可以希望楼主能够在文章中体现出来。谢谢拉~~受益匪浅~

    从性能和可靠性上使用服务器自己提供的事务支持最好,
    AtomikosTransactions此处只是演示分布式事务(如果搭建服务器环境 是比较耗时间的)


    谢谢回复了,我回过头去看了下9.1章节就明白了,JTA是为全局事务和分布式事务提供服务的,事务总共有两种类型:本地事务和全局事务。其中本地事务是自己编程去显示的控制事务。这样理解没错吧?
    6 楼 jinnianshilongnian 2012-11-02  
    縌流而上的魚 写道
    引用

    二、Spring对全局事务的支持:

    a)Jta事务管理器


    这里所讲解的例子

    引用

    但是如果确实需要使用JTA事务,请首先选择应用服务器事务管理器,本示例不适合生产环境,如果非要运用到生产环境,可以考虑购买AtomikosTransactionsEssentials商业支持。


    以及例子讲解完毕后的这句话,是否可以理解为:
    JTA事务的适用,首选应用服务器的事务管理器来管理,而不应该在自己的项目中“显示”的去定义使用他?

    还是搞的不是很明白,讲解这一章的目的在哪里?学习的目的就是为了在平时的工作和项目中用到,如果应用不到的话,或者不推荐使用的话,如果可以希望楼主能够在文章中体现出来。谢谢拉~~受益匪浅~

    这是y
    縌流而上的魚 写道
    引用

    二、Spring对全局事务的支持:

    a)Jta事务管理器


    这里所讲解的例子

    引用

    但是如果确实需要使用JTA事务,请首先选择应用服务器事务管理器,本示例不适合生产环境,如果非要运用到生产环境,可以考虑购买AtomikosTransactionsEssentials商业支持。


    以及例子讲解完毕后的这句话,是否可以理解为:
    JTA事务的适用,首选应用服务器的事务管理器来管理,而不应该在自己的项目中“显示”的去定义使用他?

    还是搞的不是很明白,讲解这一章的目的在哪里?学习的目的就是为了在平时的工作和项目中用到,如果应用不到的话,或者不推荐使用的话,如果可以希望楼主能够在文章中体现出来。谢谢拉~~受益匪浅~

    从性能和可靠性上使用服务器自己提供的事务支持最好,
    AtomikosTransactions此处只是演示分布式事务(如果搭建服务器环境 是比较耗时间的)
    5 楼 縌流而上的魚 2012-11-02  
    引用

    二、Spring对全局事务的支持:

    a)Jta事务管理器


    这里所讲解的例子

    引用

    但是如果确实需要使用JTA事务,请首先选择应用服务器事务管理器,本示例不适合生产环境,如果非要运用到生产环境,可以考虑购买AtomikosTransactionsEssentials商业支持。


    以及例子讲解完毕后的这句话,是否可以理解为:
    JTA事务的适用,首选应用服务器的事务管理器来管理,而不应该在自己的项目中“显示”的去定义使用他?

    还是搞的不是很明白,讲解这一章的目的在哪里?学习的目的就是为了在平时的工作和项目中用到,如果应用不到的话,或者不推荐使用的话,如果可以希望楼主能够在文章中体现出来。谢谢拉~~受益匪浅~
    4 楼 ak913 2012-09-19  
    jinnianshilongnian 写道
    ak913 写道
    按逻辑,datasource与transaction manager应该在配置上有所关联,不然transaction manager无法得知要管理哪个datasource的commit及rollback。
    在对本地事务的介绍中,这个关联在配置中已设定。
    但在Atomikos JTA的配置中,datasource与transaction manager的设置似乎各自完全独立,毫无关联。
    请教栏主,这。。。是何道理?


    Atomikos JTA 中使用的分布式事务,使用的是两阶段提交协议,建议您去看一下 分布式事务概念


    看来楼主误解我的问题了。我是说,无论什么Transaction mgr都应该在知晓resource是谁的前提下对resource进行管理,但文中的配置并没有显示地把resource与transaction mgr关联起来。
    我在官方文档中找到答案了:atomikos默认会对com.atomikos.jdbc.AtomikosDataSourceBean的实例进行管理,哪怕没有在配置中关联它们。
    3 楼 jinnianshilongnian 2012-03-25  
    ak913 写道
    按逻辑,datasource与transaction manager应该在配置上有所关联,不然transaction manager无法得知要管理哪个datasource的commit及rollback。
    在对本地事务的介绍中,这个关联在配置中已设定。
    但在Atomikos JTA的配置中,datasource与transaction manager的设置似乎各自完全独立,毫无关联。
    请教栏主,这。。。是何道理?


    Atomikos JTA 中使用的分布式事务,使用的是两阶段提交协议,建议您去看一下 分布式事务概念
    2 楼 ak913 2012-03-25  
    按逻辑,datasource与transaction manager应该在配置上有所关联,不然transaction manager无法得知要管理哪个datasource的commit及rollback。
    在对本地事务的介绍中,这个关联在配置中已设定。
    但在Atomikos JTA的配置中,datasource与transaction manager的设置似乎各自完全独立,毫无关联。
    请教栏主,这。。。是何道理?
    1 楼 xtrdfg 2012-03-05  
    挺好的

    相关推荐

      养老院管理系统:SpringBoot与Vue前后端不分离架构的设计与实现

      内容概要:本文详细介绍了基于SpringBoot和Vue开发的养老院管理系统的具体实现细节。该系统采用前后端不分离的架构,旨在快速迭代并满足中小项目的开发需求。文中涵盖了多个关键技术点,如数据库设计(组合唯一约束、触发器)、定时任务(@Scheduled、@Async)、前端数据绑定(Vue的条件渲染和动态class绑定)、权限控制(RBAC模型、自定义注解)以及报表导出(SXSSFWorkbook流式导出)。此外,还讨论了开发过程中遇到的一些常见问题及其解决方案,如CSRF防护、静态资源配置、表单提交冲突等。 适合人群:具备一定Java和前端开发经验的研发人员,尤其是对SpringBoot和Vue有一定了解的开发者。 使用场景及目标:适用于需要快速开发中小型管理系统的团队,帮助他们理解如何利用SpringBoot和Vue进行全栈开发,掌握前后端不分离架构的优势和注意事项。 其他说明:文章不仅提供了详细的代码示例和技术要点,还分享了许多实用的小技巧和避坑指南,有助于提高开发效率和系统稳定性。

      家族企业如何应对人才流失问题?.doc

      家族企业如何应对人才流失问题?

      员工关怀制度.doc

      员工关怀制度.doc

      路径规划领域中基于排序搜索的蚁群算法优化及其应用

      内容概要:本文详细探讨了对传统蚁群算法进行改进的方法,特别是在路径规划领域的应用。主要改进措施包括:采用排序搜索机制,即在每轮迭代后对所有路径按长度排序并只强化前20%的优质路径;调整信息素更新规则,如引入动态蒸发系数和分级强化策略;优化路径选择策略,增加排序权重因子;以及实现动态地图调整,使算法能够快速适应环境变化。实验结果显示,改进后的算法在收敛速度上有显著提升,在复杂地形中的表现更加稳健。 适合人群:从事路径规划研究的技术人员、算法工程师、科研工作者。 使用场景及目标:适用于需要高效路径规划的应用场景,如物流配送、机器人导航、自动驾驶等领域。目标是提高路径规划的效率和准确性,减少不必要的迂回路径,确保在动态环境中快速响应变化。 其他说明:改进后的蚁群算法不仅提高了收敛速度,还增强了对复杂环境的适应能力。建议在实际应用中结合可视化工具进行调参,以便更好地观察和优化蚂蚁的探索轨迹。此外,还需注意避免过度依赖排序机制而导致的过拟合问题。

      基于PSO算法的配电网分布式光伏选址定容优化及其Matlab实现

      内容概要:本文详细介绍了利用粒子群优化(PSO)算法解决配电网中分布式光伏系统的选址与定容问题的方法。首先阐述了问题背景,即在复杂的配电网环境中选择合适的光伏安装位置和确定合理的装机容量,以降低网损、减小电压偏差并提高光伏消纳效率。接着展示了具体的PSO算法实现流程,包括粒子初始化、适应度函数构建、粒子位置更新规则以及越界处理机制等关键技术细节。文中还讨论了目标函数的设计思路,将多个相互制约的目标如网损、电压偏差和光伏消纳通过加权方式整合为单一评价标准。此外,作者分享了一些实践经验,例如采用前推回代法进行快速潮流计算,针对特定应用场景调整权重系数,以及引入随机波动模型模拟光伏出力特性。最终实验结果显示,经过优化后的方案能够显著提升系统的整体性能。 适用人群:从事电力系统规划与设计的专业人士,尤其是那些需要处理分布式能源集成问题的研究人员和技术人员。 使用场景及目标:适用于希望深入了解如何运用智能优化算法解决实际工程难题的人士;旨在帮助读者掌握PSO算法的具体应用方法,从而更好地应对配电网中分布式光伏系统的选址定容挑战。 其他说明:文中提供了完整的Matlab源代码片段,便于读者理解和复现研究结果;同时也提到了一些潜在改进方向,鼓励进一步探索和创新。

      Prius2004永磁同步电机设计:从Excel到MotorCAD的全流程解析与实战技巧

      内容概要:本文详细介绍了丰田Prius2004永磁同步电机的设计流程,涵盖从初始参数计算到最终温升仿真的各个环节。首先利用Excel进行基本参数计算,如铁芯叠厚、定子外径等,确保设计符合预期性能。接着使用Maxwell进行参数化仿真,通过Python脚本自动化调整磁钢尺寸和其他关键参数,优化电机性能并减少齿槽转矩。随后借助橡树岭实验室提供的实测数据验证仿真结果,确保模型准确性。最后采用MotorCAD进行温升仿真,优化冷却系统设计,确保电机运行安全可靠。文中还分享了许多实用技巧,如如何正确设置材料参数、避免常见的仿真错误等。 适合人群:从事电机设计的专业工程师和技术人员,尤其是对永磁同步电机设计感兴趣的读者。 使用场景及目标:适用于希望深入了解永磁同步电机设计全过程的技术人员,帮助他们在实际工作中提高设计效率和精度,解决常见问题,优化设计方案。 其他说明:文章提供了丰富的实战经验和具体的操作步骤,强调了理论与实践相结合的重要性。同时提醒读者注意一些容易忽视的细节,如材料参数的选择和仿真模型的准确性。

      基于DSP28335的单相逆变器设计方案与实现:涵盖ADC采样、PWM控制、锁相环及保护机制

      内容概要:本文详细介绍了基于DSP28335的单相逆变器的设计与实现,涵盖了多个关键技术模块。首先,ADC采样模块用于获取输入电压和电流的数据,确保后续控制的准确性。接着,PWM控制模块负责生成精确的脉宽调制信号,控制逆变器的工作状态。液晶显示模块则用于实时展示电压、电流等重要参数。单相锁相环电路实现了电网电压的频率和相位同步,确保逆变器输出的稳定性。最后,电路保护程序提供了过流保护等功能,保障系统的安全性。每个模块都有详细的代码示例和技术要点解析。 适合人群:具备一定嵌入式系统和电力电子基础知识的研发人员,尤其是对DSP28335感兴趣的工程师。 使用场景及目标:适用于单相逆变器项目的开发,帮助开发者理解和掌握各个模块的具体实现方法,提高系统的可靠性和性能。 其他说明:文中不仅提供了具体的代码实现,还分享了许多调试经验和常见问题的解决方案,有助于读者更好地理解和应用相关技术。

      SecureCRT安装包

      SecureCRT安装包

      C# WPF MVVM架构下的大屏看板3D可视化开发指南

      内容概要:本文详细介绍了如何利用C#、WPF和MVVM模式构建一个大屏看板3D可视化系统。主要内容涵盖WPF编程设计、自定义工业控件、数据库设计、MVVM架构应用以及典型的三层架构设计。文中不仅提供了具体的代码实例,还讨论了数据库连接配置、3D模型绑定、依赖属性注册等关键技术细节。此外,文章强调了项目开发过程中需要注意的问题,如3D坐标系换算、MVVM中命令传递、数据库连接字符串加密等。 适合人群:具备一定C#编程基础,对WPF和MVVM模式有一定了解的研发人员。 使用场景及目标:适用于希望深入了解WPF和MVVM模式在实际项目中应用的开发者,特别是那些从事工业控制系统、数据可视化平台开发的专业人士。通过学习本文,读者可以掌握如何构建高效、稳定的大屏看板3D可视化系统。 其他说明:本文提供的设计方案和技术实现方式,可以帮助开发者更好地理解和应用WPF和MVVM模式,同时也能为相关领域的项目开发提供有价值的参考。

      基于java SSM 框架的酒店管理系统.zip

      基于ssm的系统设计,包含sql文件(Spring+SpringMVC+MyBatis)

      非厄米超表面双参数传感器的COMSOL建模与应用

      内容概要:本文详细介绍了利用COMSOL进行非厄米超表面双参数传感器的设计与实现。首先,通过构建超表面单元并引入虚部折射率,实现了PT对称系统的增益-损耗交替分布。接着,通过频域扫描和参数化扫描,捕捉到了复频率空间中的能级劈裂现象,并找到了奇异点(Exceptional Point),从而显著提高了传感器对微小扰动的敏感度。此外,文章探讨了双参数检测的独特优势,如解耦温度和折射率变化的能力,并展示了其在病毒检测、工业流程监控等领域的潜在应用。 适合人群:从事光学传感器研究的专业人士,尤其是对非厄米系统和COMSOL仿真感兴趣的科研人员。 使用场景及目标:适用于需要高精度、多参数检测的应用场合,如生物医学检测、环境监测等。目标是提高传感器的灵敏度和分辨率,解决传统传感器中存在的参数交叉敏感问题。 其他说明:文中提供了详细的建模步骤和代码片段,帮助读者理解和重现实验结果。同时,强调了在建模过程中需要注意的关键技术和常见问题,如网格划分、参数设置等。

      怎样健全员工福利体系.docx

      怎样健全员工福利体系.docx

      离职证明范本.doc

      离职证明范本.doc

      6538b79724855900a9c930904a302920.part6

      6538b79724855900a9c930904a302920.part6

      员工离职单.doc

      员工离职单.doc

      COMSOL中超材料异常折射仿真的关键技术与实现

      内容概要:本文详细介绍了在COMSOL中进行超材料异常折射仿真的关键技术。首先解释了异常折射现象及其产生的原因,接着通过具体代码展示了如何利用相位梯度和结构色散精确计算折射角。文中还讨论了边界条件的设置、网格划分的优化以及参数化扫描的应用。此外,提供了多个实用脚本和技巧,帮助提高仿真的精度和效率。最后强调了验证结果的重要性和一些常见的注意事项。 适合人群:从事电磁仿真研究的专业人士,尤其是对超材料和异常折射感兴趣的科研人员和技术开发者。 使用场景及目标:适用于需要深入理解和解决超材料中异常折射问题的研究项目。主要目标是掌握COMSOL中异常折射仿真的完整流程,确保仿真结果的准确性并优化计算性能。 其他说明:文章不仅提供了详细的代码示例和技术细节,还分享了许多实践经验,有助于读者更好地应对实际仿真过程中可能出现的问题。

      招聘工作数据分析表.xls

      招聘工作数据分析表.xls

      platform-tools-latest-windows.zip

      platform-tools-latest-windows.zip

      个人资料临时存储QT资源

      个人资料临时存储QT资源

      微电网三相交流下垂控制技术详解:传统阻感型输出有功、无功及频率波形分析

      内容概要:本文详细介绍了微电网中三相交流下垂控制的工作原理和技术细节。首先,通过Matlab/Simulink搭建模型,展示了传统阻感型线路下垂特性的实现方法,特别是有功-频率和无功-电压下垂曲线的解析。文中强调了关键参数Kp和Kq的选择及其对系统稳定性的影响,并通过具体的仿真案例展示了不同参数设置下的动态响应。此外,文章讨论了波形分析中的注意事项,如谐波成分、滤波器设计以及虚拟阻抗的应用。最后,通过Python和C语言实现了下垂控制器的代码示例,进一步解释了实际工程中的实现细节。 适合人群:从事微电网研究和开发的技术人员,尤其是对下垂控制感兴趣的电气工程师和研究人员。 使用场景及目标:适用于希望深入了解微电网下垂控制原理及其实际应用的研究人员和技术人员。目标是帮助读者掌握下垂控制的核心概念和技术实现,提高在实际工程项目中的调试和优化能力。 其他说明:文章不仅提供了理论分析,还包括了大量的仿真代码和波形图,使读者能够更好地理解和验证所学内容。同时,文中提到的实际调试经验和常见错误也为初学者提供了宝贵的指导。

    Global site tag (gtag.js) - Google Analytics