Seata报找不到全局事务,可能已经完成怎么办?

Seata报找不到全局事务,可能已经完成怎么办?
Could not found global transaction xid = %s, may be has finished.

展开
收起
你鞋带开了~ 2024-02-12 14:30:41 220 发布于辽宁 分享
分享
版权
举报
1 条回答
写回答
取消 提交回答
  • 举例说明:
    @GlobalTransactional(timeout=60000) public void A(){
    call remoting B();//远程调用B服务 local DB operation;
    }
    public void B(){
    }
    可能原因:
    A 执行的总体时间超过了60000ms,导致全局事务发起了全局回滚,此时A或B方法继续执行DB操作,校验全局事务状态,发现全局事务已经回滚。
    B服务执行超出其设定的readTimeout 返回异常给A并将异常抛出导致全局事务回滚,此时B服务执行DB操作时,校验全局事务状态,发现全局事务已经回滚。
    影响:出现这种情况时,数据会整体回滚至A方法执行前的数据的初态,从数据一致性的视角上看,数据是整体一致的。
    --此回答整理自钉群“3群-Apache Seata(incubating) 开源讨论群”

    2024-02-12 15:00:21 举报
    赞同 评论

    评论

    全部评论 (0)

    登录后可评论
AI助理

你好,我是AI助理

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