码迷,mamicode.com
首页 > 其他好文 > 详细

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

时间:2018-09-17 17:46:22      阅读:196      评论:0      收藏:0      [点我收藏+]

标签:依据   描述   完成后   inf   开启   配置   sel   color   分享图片   

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

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

问题定位

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

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

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

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

可参考下图:

技术分享图片

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

标签:依据   描述   完成后   inf   开启   配置   sel   color   分享图片   

原文地址:https://www.cnblogs.com/gannalyo/p/9662838.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!