ThinkChat🤖让你学习和工作更高效,注册即送10W Token,即刻开启你的AI之旅 广告
# Saga(试验) Saga是用来在微服务中的长事务管理,具备ACID中的ACD,不具备I,隔离性。在一定业务条件下,可以使用Saga非常简单和方便的管理微服务事务。同理,也可以用于管理多库事务 Saga要求微服务提供回滚操作,然后如果需要回滚,有Saga编排调度各个微服务对应的回滚服务。BeetlSQL提供了SagaMapper,内置的操作都有对应的回滚操作,也提供@SagaSql,用户提供正向SQL和提供回滚SQL。这样,在多库环境下,BeetlSQL能正确回滚数据而不依赖于数据库提供的事务 BeetlSQL的Saga能解决单系统多库下的事务,也能解决微服务事务,而编程方式是一致的,这是相对于其他Saga实现里说的一个优点 > 微服务中一定要使用事务么?有些系统会事先查询微服务各个参与方是否满足调用条件再进行调用和对数据修改。这能一定程度上可以不使用事务。然而,如果有任何异常,需要进行人工处理。这适合用户规模不大系统。