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

Seata中这个问题怎么解决呀?

Seata中这个问题怎么解决呀?SQLException; SQL state [null]; error code [0]; io.seata.core.exception.RmTransactionException: Response[ TransactionException[Could not found global transaction xid = 192.168.9.181:9001:99397717556435829, may be has finished.] ]; nested exception is java.sql.SQLException: io.seata.core.exception.RmTransactionException: Response[ TransactionException[Could not found global transaction xid = 192.168.9.181:9001:99397717556435829, may be has finished.] ]

展开
收起
fuxixi 2022-11-07 17:06:23 534 0
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 开源讨论群”

    2022-11-07 17:55:16
    赞同 展开评论 打赏
问答地址:

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

热门讨论

热门文章

相关电子书

更多
Nacos架构&原理 立即下载
Dubbo分布式服务治理实战 立即下载
低代码开发师(初级)实战教程 立即下载