问题1:使用Seata AT模式,在并发情况下,出现Global lock wait timeout异常,并且出现锁残留。只能重启server端,才能清理残留锁 问题2:holdingby的xid我查了数据,表都是空的,我的理解是xid有序自增的,108 -> 112 中间少了 109、110、111
回答1:残留锁只可能是因为事务决议恰好有分支注册的情况,升级到1.5以上 残留的所在2分10秒后会删除,出现这个问题去看holdingby的xid去找下数据库这个globalxid什么状态 回答2:那重启也没用,日志里查看这个xid,在时候提交或回滚了。少了正常,被上面抢锁失败的线程用过去了,锁争抢跟分支注册是一起的,先抢到锁再注册上分钟,在代码里的顺序是先创建一个branchsession ,在lock,在addbranchsession到globalsession中,此回答整理自钉群“3群-Seata 开源讨论群”
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
阿里云拥有国内全面的云原生产品技术以及大规模的云原生应用实践,通过全面容器化、核心技术互联网化、应用 Serverless 化三大范式,助力制造业企业高效上云,实现系统稳定、应用敏捷智能。拥抱云原生,让创新无处不在。