浮生若梦l 2023-02-08 12:08 采纳率: 0%
浏览 32
已结题

事务与分布式锁调用问题

事务与分布式锁调用问题
1.首先我知道事务需要置于分布式锁中才能保证分布式锁生效,否则事务没有提交完成就进入下一个线程,则数据高并发时会出现错乱。
2.如今遇到一个问题,封装好的一个红包退款方法,使用的是method1(分布式锁方法-调用-事务方法退款)。然后,这个时候另外一个事务方法method2需要调用这个分布式方法 method1,method2中有数据更改,这个时候会出现method1中的事务方法失效或者这两个事务方法是否在同一个事务中
3.猜想--从method2到method1整个方法调用中,都置于method2的事务中,此时并发会出现数据错乱问题

调用模型1:分布式锁方法m2-调用 事务方法m3
调用模型2:事务方法m1 调用 分布式锁方法m2-调用事务方法m3(此种模型是否跟以上第3点猜想结果一直,希望大家解惑,谢谢)

  • 写回答

3条回答 默认 最新

  • 踢足球的阿坤 2023-02-08 12:56
    关注

    此种模型就是第三点猜想的结果,可能会出现数据错乱问题,在调用模型2中要确保分布式锁锁定的是事务方法L3,否则就会出现错误的数据。

    评论

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 1月12日
  • 创建了问题 2月8日