zoukankan      html  css  js  c++  java
  • spring 事务属性

    本文介绍spring事务的5个属性

      spring中,声明事务是通过事务属性来定义的。事务属性描述了事务策略如何应用到方法上事务属性包含5个方面:

    • 传播行为
    • 隔离级别
    • 回滚规则
    • 事务超时
    • 是否只读

      传播行为

      传播行为定义了客户端与被调用方法之间的事务边界,即传播规则回答了这样的一个问题,新的事务应该被启动还是挂起,或者方法是否要在事务环境中运行。7中传播规则:

    1. PROPAGATION_MANDATORY(强制传播):表示该方法必须在事务中运行,如果当前事务不存在,则会抛出一个异常
    2. PROPAGATION_NESTED(嵌套传播):表示如果当前存在一个事务,那么该方法就回在嵌套事务中运行,嵌套的事务可以独立于当前事务进行单独地提交或回滚,如果当前事务不存在,那么其行为与PROPAGATION_REQUIRED一样
    3. PROPAGATION_NEVER:(从不传播):表示当前方法不应该运行在事务上下文中,如果档期正有一个事务在运行,则会抛出异常
    4. PROPAGATION_NOT_SUPPORED(不支持传播):表示该方法不应该运行在事务中,如果存在当前事务,在该方法运行期间,当前事务将会被挂起
    5. PROPAGATION_REQUIRED(必要传播):表示当前事务必须运行在事务中,如果当前事务存在,方法将会在该事务中运行,否则,会启动一个新的事务
    6. PROPAGATION_REQUIRED_NEW(新建必要传播):表示当前方法必须运行在自己的事务当中(运行在一个新建的事务当中),如果当前存在事务,当前事务挂起 
    7. PROPAGATION_SUPPORT(支持事务):表示当前方法不需要事务上下文,但是如果存在当前事务的话,那么盖房会在这个事务中运行

      隔离界别

      隔离级别定义了一个事务可能受其他并发事务影响的程度。

      多个并发事务可能会导致一下问题:

    1. 脏读---脏读发生在一个事务独缺了冰一个事务改写但尚未提交的数据时,如果改写在稍后被回滚了,那么第一个事务获取的数据就是无效的。
    2. 不可重复读---不可重复读发生在一个事务执行相同的查询两次或两次以上,但是每次都得到不同的数据时,这通常是因为另一个并发事务在两次查询期间更新了数据。
    3. 幻读---幻读发生在一个事务读取了几行数据,接着另外一个事务插入了一些数据,在随后的查询中,第一格式就回发现多了一些原本不存在的记录。

      隔离规则:

    1. ISOLATION_DEFAULT:使用后端数据库默认的规则
    2. ISOLATION_READ_UNCOMMITTED:允许读取尚未提交的数据变更,可能会导致脏读,幻读或不可重复读
    3. ISOLATION_READ_COMMITTED:允许读取并发事务已经提交的数据,可以防止脏读,但是幻读或不可重复读仍有可能发生
    4. ISOLATION_REPEATABLE_READ:对同意字段的多次读取结果是一致的,除非数据是被本事务自己所修改,看阻止脏读和不可重复读,但幻读仍有可能发生
    5. ISOLATIOM_SERIALIZABLE:完全服从ACID的隔离级别,确保阻止脏读,不可重复读以及幻读,这是最慢的数据隔离级别

      是否只读

      如果事务只对后端的数据库进行读操作,数据库可以利用事务ID只读特性来进行一些特定的优化。通过将事务设置为只读,你就可以给数据库一个机会,让他应用它认为合适的优化措施。因为是否只读是在事务启动的时候由数据库实施的,所以只有对那些具备可能启动一个新事务的传播行为(PROPAGATION_REQUIRED,PROPAGATION_REQUIRED_NEW,PROPAGATION_NESTED)的方法来说,才有意义。

      事务超时

      为了使应用程序很好地运行,事务不能运行太长时间。因为超时时钟会在事务开始时启动,所以只有对那些具备可能启动一个新事务的传播行为(PROPAGATION_REQUIRED,PROPAGATION_REQUIRED_NEW,PROPAGATION_NESTED)的方法来说,才有意义。

      

      事务回滚

      事务回滚规则定义了哪些异常会导致事务回滚而哪些不会。默认情况下,事务只有在遇到运行时期异常才回滚,而在遇到检查型异常时不会回滚。

    具体看下XML配置

    <tx:annotation-driven /> 
    <tx:advice id="txAdvice" transactionmanager="transactionManager">
            <tx:attributes>
                <tx:method name="*" propagation="REQUIRED"/>
            </tx:attributes>
    </tx:advice>
    <aop:config expose-proxy="true" proxy-target-class="true">
            <!-- 只对业务逻辑层实施事务 -->
            <aop:pointcut id="txPointcut" expression="execution(* com.weiaigongdi.access..service..*+.*(..))"/>
            <aop:advisor id="txAdvisor" advice-ref="txAdvice" pointcut-ref="txPointcut"/>
    </aop:config>
    <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> 
             <property name="dataSource" ref="ds1" /> 
    </bean> 
  • 相关阅读:
    JS模拟出 getElementsByClassName 功能
    如何为PDF文件添加书签
    Linux内核模块学习
    Linux字符设备驱动学习
    第53篇编译线程的初始化
    第51篇SharedRuntime::generate_native_wrapper()生成编译入口
    第50篇调用约定(2)
    第52篇即时编译器
    2021 阿里云容器服务年度盘点:企业级容器应用变化和技术趋势观察
    如何在零停机的情况下迁移 Kubernetes 集群
  • 原文地址:https://www.cnblogs.com/gongdi/p/5026336.html
Copyright © 2011-2022 走看看