【问题标题】:Spring transaction rollback happens only first timeSpring事务回滚只发生在第一次
【发布时间】:2014-06-25 06:18:59
【问题描述】:

这很奇怪,但我可能在这里遗漏了一些东西

我正在使用quartz 来初始化spring config xml。当我第一次触发石英作业时,发生异常时事务会回滚。但是当再次触发相同的作业时,事务不会因相同的异常而回滚。

我可以从日志中看到,当第一次触发作业时,数据源(从 Websphere 数据源对 Sybase Jconnect 7 的 jndi 查找)被初始化(不是第二次)。

服务层

@Transactional(value="transactionManager", propagation=Propagation.REQUIRES_NEW, rollbackFor=Exception.class)
public void saveInfo(
        List<Foo> saveData) throws Exception {

    try{

        myDAO.saveInfo(saveData); //data to rollback on exception. Works First time only :(
    }
    catch(Exception ex){
        logBO.createActivityLog("Error Saving Data");
        throw ex;
    }
}

Spring-config.xml

<tx:annotation-driven transaction-manager="transactionManager"/>

<bean id="transactionManager"  class="org.springframework.orm.hibernate3.HibernateTransactionManager">
    <property name="sessionFactory">
         <ref local="sessionFactory"/>
    </property>
</bean>

我已经使用了所有 REQUIRED/REQUIRES_NEW/没有传播的传播设置。

DAO 方法进行批量更新 (jdbcTemplate)

编辑

在第一次时,此行被记录

J2CA0086W: 可共享连接 MCWrapper id 4c384c38 托管 连接 WSRdbManagedConnectionImpl@6f5a6f5a 状态:使用了资源 mydatasource 中的STATE_TRAN_WRAPPER_INUSE 在本地事务包含边界内。

【问题讨论】:

    标签: java spring transactions quartz-scheduler


    【解决方案1】:

    试试这个:

    @TransactionConfiguration(transactionManager = "txManager",defaultRollback = true)
    @Transactional
    

    休眠和数据源代码:

        <!-- Hibernate Related Configuration. -->
    
        <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
            <property name="driverClassName" value="org.postgresql.Driver"/>
            <property name="url" value="jdbc:postgresql://192.168.1.9:5432/dbname"/>
            <property name="username" value="postgres"/>
            <property name="password" value="pwd"/>
            <property name="validationQuery" value="SELECT 1"/>
        </bean>
    
        <bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
            <property name="dataSource" ref="dataSource"/>
            <property name="packagesToScan" value="com.domain"/>
            <property name="hibernateProperties">
                <props>
                    <prop key="hibernate.dialect">org.hibernate.dialect.PostgreSQLDialect</prop>
                    <prop key="hibernate.show_sql">true</prop>
                    <prop key="hibernate.format_sql">true</prop>
                    <prop key="hibernate.generate_statistics">true</prop>
                </props>
            </property>
        </bean>
    

    和 txManager:

    <!-- Transaction Manager -->
    <bean id="txManager"
          class="org.springframework.orm.hibernate3.HibernateTransactionManager">
        <property name="sessionFactory" ref="sessionFactory" />
    </bean>
    
    <tx:annotation-driven transaction-manager="txManager" />
    

    别忘了加一行:

    <property name="packagesToScan" value="com.domain"/>
    

    在 sessionfactory 中,由于这个问题发生了很多次。

    【讨论】:

    • 谢谢!但这会阻止服务类甚至加载。线程只是挂起,数据源初始化后没有任何反应。
    • 你能告诉我你的 xml 数据源代码吗?具有连接属性。
    • 抱歉回复延迟。但问题似乎在于 spring 配置中有多个事务管理器。我无法解释原因,但是有多个事务管理器(我尝试过组合 hibernate tm-hibernate tm、hibernate tm - DataSourceTM、WebSphereUowTM)在异常时无法回滚。
    猜你喜欢
    • 2019-02-09
    • 1970-01-01
    • 2011-11-21
    • 1970-01-01
    • 1970-01-01
    • 2016-09-19
    • 2017-03-03
    • 2012-03-10
    • 2018-07-15
    相关资源
    最近更新 更多