博客
关于我
Spring事务传播属性和隔离级别
阅读量:316 次
发布时间:2019-03-03

本文共 1427 字,大约阅读时间需要 4 分钟。

Spring事务传播属性和隔离级别

Spring事务传播属性(Propagation)

在Spring中,事务传播属性决定了如何处理方法调用的事务关系。默认情况下,Spring使用REQUIRED属性,这表示如果存在一个已经激活的事务,当前方法会支持这个事务;如果没有事务,则会开启一个新的事务。这种传播方式确保了每个方法调用的逻辑事务域是独立的,前后方法之间不会互相影响。

传播属性的具体实现

  • REQUIRED(默认):如果有活性的事务存在,当前方法会参与这个事务;如果没有,则新建一个独立的事务。
  • MANDATORY:要求当前方法必须参与已有的事务。如果没有活性的事务,会抛出TransactionRequiredException
  • NEVER:禁止当前方法参与任何事务。如果有活性的事务,会抛出TransactionException
  • NOT_SUPPORTED:禁止当前方法参与事务。如果有活性的事务,会暂停当前事务并以非事务模式执行。
  • REQUIRES_NEW:强制创建新的事务。如果有活性的事务,会暂停当前事务并启动一个新的事务。
  • SUPPORTS:支持当前事务,如果没有活性事务,则以非事务模式执行。
  • NESTED:支持嵌套事务,与当前事务共享一个Savepoint,确保嵌套事务的提交与外层事务同步。
  • 传播属性的区别

    • REQUIRES_NEWNESTED:它们都要求新建事务,但REQUIRES_NEW创建的是独立的事务,外层事务无法回滚内层事务;而NESTED创建的是嵌套事务,外层事务的回滚会影响内层事务。

    传播属性的意义

    选择正确的事务传播属性对于应用程序的行为至关重要。例如,使用REQUIRES_NEW可以确保不同方法调用的事务相互独立,而NESTED则允许细粒度的控制,最大限度地利用已有的事务资源。


    Spring事务隔离级别(Isolation Level)

    事务的隔离级别决定了在并发环境下如何处理事务的读写冲突。不同的隔离级别提供了不同的并发控制机制,防止并发事务导致的数据不一致。

    并发问题

  • 脏读(Dirty Reads):一个事务读取未提交的数据,可能看到其他事务的修改。
  • 不可重复读(Non-Repeatable Reads):一个事务多次读取同一数据,结果受到其他事务修改的影响。
  • 幻像读(Phantom Reads):一个事务多次读取同一数据,结果受到其他事务插入的影响。
  • 隔离级别

  • DEFAULT(默认):使用数据库的默认隔离级别,通常为READ_COMMITTED
  • READ_UNCOMMITTED:最低隔离级别,允许读取未提交的事务数据,会导致脏读。
  • READ_COMMITTED:确保读取的数据是已提交的事务数据,避免脏读,但仍可能出现不可重复读。
  • REPEATABLE_READ:防止脏读和不可重复读,允许同一事务多次读取相同数据。
  • SERIALIZABLE:最高隔离级别,确保事务按顺序执行,防止任何形式的数据不一致。
  • 隔离级别的意义

    选择合适的隔离级别需要权衡数据一致性和性能。SERIALIZABLE虽然可靠,但会显著增加系统开销;而REPEATABLE_READ提供了较好的性能和数据一致性。


    通过合理配置事务传播属性和隔离级别,可以有效管理多个事务之间的关系,确保系统的数据一致性和高可用性。在实际应用中,需要根据业务需求选择最适合的隔离级别和传播属性,以实现高效且安全的事务管理。

    转载地址:http://sigl.baihongyu.com/

    你可能感兴趣的文章
    Nginx安装与常见命令
    查看>>
    nginx安装与配置
    查看>>
    【Flink】Flink 2023 Flink 到 Doris 实时写入实践
    查看>>
    Nginx安装及配置详解
    查看>>
    nginx安装并配置实现端口转发
    查看>>
    nginx安装配置
    查看>>
    Nginx实战之1.1-1.6 Nginx介绍,安装及配置文件详解
    查看>>
    Nginx实战经验分享:从小白到专家的成长历程!
    查看>>
    nginx实现二级域名转发
    查看>>
    Nginx实现动静分离
    查看>>
    Nginx实现反向代理负载均衡
    查看>>
    nginx实现负载均衡
    查看>>
    Nginx实现负载均衡时常用的分配服务器策略
    查看>>
    Nginx实现限流
    查看>>
    Nginx将https重定向为http进行访问的配置(附Demo)
    查看>>
    Nginx屏蔽电脑端访问,但不限制蜘蛛爬取
    查看>>
    nginx工作笔记004---配置https_ssl证书_视频服务器接口等
    查看>>
    nginx工作笔记005---nginx配置负载均衡_在微服务中实现网关集群_实现TCP传输层协议__http协议的负载均衡
    查看>>
    nginx常用命令及简单配置
    查看>>
    Nginx常用屏蔽规则,让网站更安全
    查看>>