日常Bug排查-应用Commit报错事务并没有回滚

网友投稿 707 2023-04-05

本站部分文章、图片属于网络上可搜索到的公开信息,均用于学习和交流用途,不能代表睿象云的观点、立场或意见。我们接受网民的监督,如发现任何违法内容或侵犯了您的权益,请第一时间联系小编邮箱jiasou666@gmail.com 处理。

日常Bug排查-应用Commit报错事务并没有回滚

日常Bug排查系列都是一些简单Bug排查,笔者将在这里介绍一些排查Bug的简单技巧,同时顺便积累素材_。

应用Commit报错并不一定回滚

事实上,这篇文章并没有什么排查过程。但这个问题却又是笔者经常遇到的。

笔者仅仅是想阐述一下当我们在事务Commit报错时候,数据库中的数据并不一定会是我们以为的回滚状态。笔者举个例子:

在这种情况下,很明显的DB的数据肯定是处于已经提交的状态。而如果App认为是回滚状态,并基于这个信息去做操作的话,很明显会导致数据不一致。

非IO or 超时异常 也不一定回滚

应用应该怎么做呢?

事实上,由于数据库保证了原子性。所以我们在遇到这种情况时候,需要从数据库中重建状态,而不是依赖现在应用里面的信息。所以遇到异常直接将流程结束,然后等定时任务等补单操作是个比较简单安全的做法。

总结

Commit报错但事务并没有回滚,这个虽然有点反直觉,但这确是在产线真实存在的,尤其在数据库压力大的时候极易出现。这个坑在我们编写代码的时候需要牢记!

上一篇:告警分析的数据挖掘(告警信息处理)
下一篇:如何在Windows 11中恢复动态磁贴
相关文章

 发表评论

暂时没有评论,来抢沙发吧~