Redis的竞争并发该如何解决?

这个也是线上非常常见的一个问题,就是多客户端同时并发写一个key,可能本来应该先到的数据后到了,导致数据版本错了。或者是多客户端同时获取一个key,修改值之后再写回去,只

      要顺序错了,数据就错了。

    而且redis自己就有天然解决这个问题的CAS类的乐观锁方案

    解决方案:使用分布式锁(zookeeper):

      1;确保同一时间只能有一个系统实例在操作某个key,别人都不允许读和写

      2,每次写之前,先判断一下当前这个value的时间戳是否比缓存里的value的时间戳要更新,如果更新,那么就可以写入到redis中.

猜你喜欢

转载自www.cnblogs.com/qingmuchuanqi48/p/11117833.html