开发者社区 > 云原生 > 中间件 > 正文

怎么使用Seata框架,来保证事务的隔离性?

怎么使用Seata框架,来保证事务的隔离性?

展开
收起
真的很搞笑 2023-03-18 18:24:00 436 0
3 条回答
写回答
取消 提交回答
  • A: 因seata一阶段本地事务已提交,为防止其他事务脏读脏写需要加强隔离。

    脏读 select语句加for update,代理方法增加@GlobalLock+@Transactional或@GlobalTransaction 脏写 必须使用@GlobalTransaction 注:如果你查询的业务的接口没有GlobalTransactional 包裹,也就是这个方法上压根没有分布式事务的需求,这时你可以在方法上标注@GlobalLock+@Transactional 注解,并且在查询语句上加 for update。 如果你查询的接口在事务链路上外层有GlobalTransactional注解,那么你查询的语句只要加for update就行。设计这个注解的原因是在没有这个注解之前,需要查询分布式事务读已提交的数据,但业务本身不需要分布式事务。 若使用GlobalTransactional注解就会增加一些没用的额外的rpc开销比如begin 返回xid,提交事务等。GlobalLock简化了rpc过程,使其做到更高的性能。,此回答整理自钉群“3群-Seata 开源讨论群”

    2023-03-22 10:16:28
    赞同 展开评论 打赏
  • 发表文章、提出问题、分享经验、结交志同道合的朋友

    Seata 是一个分布式事务解决方案,用于解决分布式环境下的事务问题。在使用 Seata 时,可以通过以下步骤实现:

    • 注册 Seata 服务:在应用程序中使用 Seata Client 注册 Seata 服务。

    • 定义 Seata 分布式事务组:在每个事务参与方中,需要将所有参与此事务的资源(包括数据库、消息队列等)加入到同一分布式事务组中。

    • 开启 Seata 分布式事务:在进行跨服务的事务操作时,需要通过 Seata 开启一个分布式事务。

    • 提交或回滚 Seata 分布式事务:在所有参与方执行完事务操作后,需要通过 Seata 提交或回滚分布式事务。

    2023-03-19 20:58:03
    赞同 展开评论 打赏
    • 自动化的代理了DataSource,自动化实现了补偿逻辑,降低了业务代码入侵。

    • TC事务协调者的引入,简化了一些事务控制逻辑。

    • 分布式事务的隔离性通过全局锁和本地锁来保证实现了写隔离和读隔离。

    2023-03-19 08:05:12
    赞同 展开评论 打赏
问答地址:

为企业提供高效、稳定、易扩展的中间件产品。

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载