Seata中Global lock wait timeout是为什么呢?

Seata中Global lock wait timeout是为什么呢?

展开
收起
fuxixi 2022-07-01 14:54:56 8178 分享 版权
1 条回答
写回答
取消 提交回答
  • 获取全局锁失败,一般是出现分布式资源竞争导致,请保证你竞争资源的周期是合理的,并且在业务上做好重试。当一个全局事务因为获取锁失败的时候,应该重新完整地从@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 开源讨论群”

    2022-07-01 15:33:22
    赞同 展开评论

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

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