乐观锁在处理高并发的时候可能会出现问题?

2019-03-07 18:02:42 +08:00
 old18

一个面试问题: 面试官说在多进程且并发量极高的情况下乐观锁会不灵光... 我有点理解不上去了...

2886 次点击
所在节点   2019
5 条回复
hilbertz
2019-03-07 18:30:14 +08:00
这取决于出现数据争用的概率,如果数据争用概率高的话,无论什么锁都没用,但如果争用概率不高的话,显然乐观锁的吞吐率要高于其他并发控制
mortonnex
2019-03-07 18:31:26 +08:00
如果真的是多进程而不是多线程
那我倒是想到一种情况:用 redis 做分布式锁

试想以下步骤:
1.clientA setnx masterA 获取到锁
2.masterA 在 slave 同步前挂掉
3.slave 变为 master
4.clientB setnx 也获取到锁

这时出现了两个 client 持有同一个锁

解决这个问题可以用 redlock,但是 redlock 不是银弹,会遇到系统时钟回调造成的问题
mejee
2019-03-07 18:35:49 +08:00
乐观锁可能存在 ABA 问题,但是是可以用版本戳解决。其他的问题倒是没有听说过
watzds
2019-03-07 23:48:32 +08:00
悲剧情况下你还乐观能有好结果吗
c4f36e5766583218
2019-03-08 11:14:18 +08:00
row was updated or deleted by another transaction (or unsaved-value mapping was incorrect) ???, 23333333

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/542239

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX