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

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

  •  1
     
  •   old18 · 2019-03-07 18:02:42 +08:00 · 2904 次点击
    这是一个创建于 2126 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

    5 条回复    2019-03-08 11:14:18 +08:00
    hilbertz
        1
    hilbertz  
       2019-03-07 18:30:14 +08:00
    这取决于出现数据争用的概率,如果数据争用概率高的话,无论什么锁都没用,但如果争用概率不高的话,显然乐观锁的吞吐率要高于其他并发控制
    mortonnex
        2
    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
        3
    mejee  
       2019-03-07 18:35:49 +08:00 via Android
    乐观锁可能存在 ABA 问题,但是是可以用版本戳解决。其他的问题倒是没有听说过
    watzds
        4
    watzds  
       2019-03-07 23:48:32 +08:00 via Android
    悲剧情况下你还乐观能有好结果吗
    c4f36e5766583218
        5
    c4f36e5766583218  
       2019-03-08 11:14:18 +08:00
    row was updated or deleted by another transaction (or unsaved-value mapping was incorrect) ???, 23333333
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2654 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 18ms · UTC 03:06 · PVG 11:06 · LAX 19:06 · JFK 22:06
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.