开发者社区 > 云原生 > 正文

Seata 怎么处理 io.seata.rm.datasource.exec.LockConflic

Seata 怎么处理 io.seata.rm.datasource.exec.LockConflictException: get global lock fail?

展开
收起
真的很搞笑 2023-04-25 12:20:16 163 0
1 条回答
写回答
取消 提交回答
  • A: 获取全局锁失败,一般是出现分布式资源竞争导致,请保证你竞争资源的周期是合理的,并且在业务上做好重试。当一个全局事务因为获取锁失败的时候,应该重新完整地从@Globaltransational的TM端重新发起。 Seata提供了一个“全局锁重试”功能,默认未开启,可以通过下面这个配置来开启。 #遇到全局锁冲突时是否回滚,默认为true client.rm.lock.retryPolicyBranchRollbackOnConflict=false 开启后,默认的全局锁重试逻辑是:线程sleep 10ms,再次争全局锁,最多30次 #你可通过这2个配置来修改锁重试机制 client.rm.lock.retryInterval=10 client.rm.lock.retryTimes=30 另外,你也可以直接在@GlobalTransactional上单独配置重试逻辑,优先级比Seata全局配置更高 @GlobalTransactional(lockRetryInternal = 100, lockRetryTimes = 30) // v1.4.2 @GlobalTransactional(lockRetryInterval = 100, lockRetryTimes = 30) // v1.5,此回答整理自钉群“3群-Seata 开源讨论群”

    2023-04-27 08:18:48
    赞同 展开评论 打赏
问答标签:
问答地址:

阿里云拥有国内全面的云原生产品技术以及大规模的云原生应用实践,通过全面容器化、核心技术互联网化、应用 Serverless 化三大范式,助力制造业企业高效上云,实现系统稳定、应用敏捷智能。拥抱云原生,让创新无处不在。

相关电子书

更多
多IO线程优化版 立即下载
低代码开发师(初级)实战教程 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载