并发请求 + 事务嵌套 + 更新数据 = 死锁

本文通过一个具体的案例,深入分析了在并发环境下由于不当的事务配置导致的死锁问题。详细探讨了问题的原因,并提供了相应的解决思路。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今有幸为同事排查死锁问题。

问题描述:一个get接口,内依据参数执行select ... for update,未考虑并发场景,导致程序死锁,且只要并发请求该接口,几乎百发百中。

问题定位

  1.检测数据库死锁情况,结果无。

  2.接口内无相关共享资源,不会死锁

  3.由于从事许久事务方面工作,所以想到了事务传播机制,果不出所料,其配置文件中get*接口配置的传播机制是SUPPORTS,故判断应该是事务嵌套死锁。

问题解释:A请求开启新事物执行update,此时来了B请求update,由于是SUPPORTS,所以加入A事务,A事务中语句执行完毕但事务需等待B完成后才能提交,而B中语句需等待A中提交后才能执行,所以出现了并发请求 事务嵌套 数据库更新导致死锁问题。

可参考下图:

转载于:https://www.cnblogs.com/gannalyo/p/9662838.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值