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

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

展开
收起
真的很搞笑 2023-03-18 17:55:44 474 发布于浙江 分享
分享
版权
举报
3 条回答
写回答
取消 提交回答
  • 因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:13:46 举报
    赞同 评论

    评论

    全部评论 (0)

    登录后可评论
  • 发表文章、提出问题、分享经验、结交志同道合的朋友

    是的,Seata框架支持MySQL和Oracle等多种关系型数据库的分布式事务处理。

    Seata中使用的是基于“两阶段提交”协议的分布式事务实现方式,它可以对多个数据库进行事务管理,确保数据的一致性。对于MySQL数据库,Seata支持原生的InnoDB存储引擎和XA事务协议,对于Oracle数据库,Seata则支持XA事务协议。

    Seata还支持多种方式的数据源集成,例如Druid、HikariCP等,使得Seata可以适配各种场景下的数据库访问需求。同时,Seata提供了丰富的配置和扩展机制,能够方便地进行二次开发和扩展,以满足各种特定的业务需求。

    2023-03-19 14:39:29 举报
    赞同 评论

    评论

    全部评论 (0)

    登录后可评论
  • 因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-19 08:05:14 举报
    赞同 评论

    评论

    全部评论 (0)

    登录后可评论

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

收录在圈子:
+ 订阅
阿里云中间件主要有包含这么几个: 分布式关系型数据库DRDS_水平拆分 做数据库扩展性的 、消息队列MQ 是做消息的中间件、企业级分布式应用服务EDAS 做分布式服务的、还有一些其他的中间件,比如配置服务、缓存等等。
还有其他疑问?
咨询AI助理
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等