乐观锁和悲观锁的使用

1.乐观锁和悲观锁各自的机制
  a. 乐观锁是一种思想,具体实现是,表中有一个版本字段(或者是时间戳),第一次读的时候,获取到这个字段。处理完业务逻辑开始更新的时候,需要再次查看该字段的值是否和第一次的一样。如果一样更新,反之拒绝。之所以叫乐观,因为这个模式没有从数据库加锁。

  b. 悲观锁是读取的时候为后面的更新加锁,之后再来的读操作都会等待。这种是数据库锁, 乐观锁优点程序实现,不会存在死锁等问题。他的适用场景也相对乐观。阻止不了除了程序之外的数据库操作。悲观锁是数据库实现,他阻止一切数据库操作。

2.乐观锁和悲观锁使用判断

  a.响应速度:如果需要非常高的响应速度,建议采用乐观锁方案,成功就执行,不成功就失败,不需要等待其他并发去释放锁

  b.冲突频率:如果冲突频率非常高,建议采用悲观锁,保证成功率,如果冲突频率大,乐观锁会需要多次重试才能成功,代价比较大

  c.重试代价:如果重试代价大,建议采用悲观锁



作者:iseeyou
链接:https://www.zhihu.com/question/29420056/answer/148053110
来源:知乎
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

2.业务中使用的悲观锁例子
   a.投票系统:用户投票,含有投票总数的表,加锁,统计投票数。配合方法名添加注解@Transactional
      select * from tb_vote where user_id=43 for update;








引用链接:https://www.zhihu.com/question/29420056/answer/7336767

猜你喜欢

转载自blog.csdn.net/qq_33919114/article/details/79312261
今日推荐