首页   注册   登录
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX  ›  2019

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

  •  1
     
  •   old18 · 274 天前 · 1095 次点击
    这是一个创建于 274 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

    5 回复  |  直到 2019-03-08 11:14:18 +08:00
        1
    hilbertz   274 天前
    这取决于出现数据争用的概率,如果数据争用概率高的话,无论什么锁都没用,但如果争用概率不高的话,显然乐观锁的吞吐率要高于其他并发控制
        2
    mortonnex   274 天前
    如果真的是多进程而不是多线程
    那我倒是想到一种情况:用 redis 做分布式锁

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

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

    解决这个问题可以用 redlock,但是 redlock 不是银弹,会遇到系统时钟回调造成的问题
        3
    mejee   274 天前 via Android
    乐观锁可能存在 ABA 问题,但是是可以用版本戳解决。其他的问题倒是没有听说过
        4
    watzds   274 天前 via Android
    悲剧情况下你还乐观能有好结果吗
        5
    c4f36e5766583218   273 天前
    row was updated or deleted by another transaction (or unsaved-value mapping was incorrect) ???, 23333333
    关于   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   2329 人在线   最高记录 5043   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.3 · 25ms · UTC 02:44 · PVG 10:44 · LAX 18:44 · JFK 21:44
    ♥ Do have faith in what you're doing.