乐观锁和悲观锁的区别
来源:互联网 发布:上海重庆火锅 知乎 编辑:程序博客网 时间:2024/05/22 01:58
先说乐观锁和悲观锁的机制:
1. 乐观锁是一种思想,具体实现是,表中有一个版本字段,第一次读的时候,获取到这个字段。处理完业务逻辑开始更新的时候,需要再次查看该字段的值是否和第一次的一样。如果一样更新,反之拒绝。之所以叫乐观,因为这个模式没有从数据库加锁。
2. 悲观锁是读取的时候为后面的更新加锁,之后再来的读操作都会等待。这种是数据库锁
乐观锁优点程序实现,不会存在死锁等问题。他的适用场景也相对乐观。阻止不了除了程序之外的数据库操作。
悲观锁是数据库实现,他阻止一切数据库操作。
再来说更新数据丢失,所有的读锁都是为了保持数据一致性。乐观锁如果有人在你之前更新了,你的更新应当是被拒绝的,可以让用户从新操作。悲观锁则会等待前一个更新完成。这也是区别。两种锁各有优缺点,不可认为一种好于另一种,像乐观锁适用于写比较少的情况下,即冲突真的很少发生的时候,这样可以省去了锁的开销,加大了系统的整个吞吐量。但如果经常产生冲突,上层应用会不断的进行retry,这样反倒是降低了性能,所以这种情况下用悲观锁就比较合适。
具体业务具体分析
一般我们可以从如下几个方面来判断:
1.响应速度:如果需要非常高的响应速度,建议采用乐观锁方案,成功就执行,不成功就失败,不需要等待其他并发去释放锁
2.冲突频率:如果冲突频率非常高,建议采用悲观锁,保证成功率,如果冲突频率大,乐观锁会需要多次重试才能成功,代价比较大
3.重试代价:如果重试代价大,建议采用悲观锁
阅读全文
0 0
- 乐观锁和悲观锁的区别
- 乐观锁和悲观锁的区别
- 乐观锁和悲观锁的区别
- 乐观锁和悲观锁的区别
- 乐观锁和悲观锁的区别
- 乐观锁和悲观锁的区别
- 乐观锁和悲观锁的区别
- 乐观锁和悲观锁的区别
- 乐观锁和悲观锁的区别
- 乐观锁和悲观锁的区别
- 乐观锁和悲观锁的区别
- 悲观锁和乐观锁的区别
- 乐观锁和悲观锁的区别
- 乐观锁和悲观锁的区别
- 悲观锁和乐观锁的区别
- 乐观锁和悲观锁的区别
- 乐观锁和悲观锁的区别
- 悲观锁和乐观锁的区别
- LeetCode-Easy刷题(16) Climbing Stairs
- payload请求
- 两个栈实现一个队列和两个队列实现一个栈
- 数据结构-循环双链表
- 服务器上的 Git
- 乐观锁和悲观锁的区别
- hdu3572-Task Schedule(最大流(ISAP),是否满流)
- LeetCode-Easy刷题(17) Remove Duplicates from Sorted List
- 服务器上的 Git
- LeetCode-Easy刷题(18) Merge Sorted Array
- ACM刷题狗的心路历程2
- 日刷(距上次好像5天了) Uva10881
- 异常处理
- LeetCode-Easy刷题(19) Same Tree