Seata-1.5.2报Global lock wait timeout怎么回事?

Seata-1.5.2报Global lock wait timeout怎么回事?

展开
收起
鸡蛋灌饼儿 2023-01-15 15:29:49 1163 发布于吉林 分享
分享
版权
举报
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群-Seata 开源讨论群”

    2023-01-15 19:30:30 发布于吉林 举报
    赞同 评论

    评论

    全部评论 (0)

    登录后可评论

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

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

你好,我是AI助理

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