乐观锁和悲观锁理解和应用场景

一、锁的含义

乐观锁:
    顾名思义,对当前操作的数据保持一个乐观的态度,认为不会有其他事务操作修改当前的数据记录。只有在提交事务更新时,会检测有没有被修改。若有则直接选择retry或定义的操作。例子:hiberante的version版本控制

悲观锁:
    悲观锁认为其他事务会对操作的数据进行修改,所以当查询时将数据上锁。若其他事务需要操作该数据则需要等待。例子:数据库中的行锁,表锁。

二、应用场景

乐观锁
   说应用场景之前,先要明白乐观锁是为了防止事务更新丢失。先讲一下更新丢失的问题。下面举个例子说明一下
商品扣库存的例子:
image

最终正确的库存应该为98。而上面发生了更新丢失,所以导致库存数不正确
为了解决这个问题,可以采用版本号进行控制
image

三、如何选择

需要结合这两种锁的特点,进行合理的选择
- 响应速度:选择乐观锁。要么冲突失败要么快速成功。悲观锁则需要等待释放锁才能被执行
- 冲突频率:频率高的话不应选择乐观锁,需要重试好几次,代价大。而悲观锁保证成功率
- 重试代价:若重试代价大则选择悲观锁

参考
CAS下ABA问题解决方案
https://mp.weixin.qq.com/s/xMoQk99N2gyz7ftBfcTLGQ

猜你喜欢

转载自blog.csdn.net/Yoga0301/article/details/80470195
今日推荐