redis乐观锁(适用于秒杀系统)

Posted crazyYong

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了redis乐观锁(适用于秒杀系统)相关的知识,希望对你有一定的参考价值。

redis事务中的WATCH命令和基于CAS的乐观锁
 在Redis的事务中,WATCH命令可用于提供CAS(check-and-set)功能。假设我们通过WATCH命令在事务执行之前监控了多个Keys,倘若在WATCH之后有任何Key的值发生了变化,EXEC命令执行的事务都将被放弃,同时返回Nullmulti-bulk应答以通知调用者事务执行失败。例如,我们再次假设Redis中并未提供incr命令来完成键值的原子性递增,如果要实现该功能,我们只能自行编写相应的代码。其伪码如下:
     val = GET mykey
     val = val + 1
     SET mykey $val
    以上代码只有在单连接的情况下才可以保证执行结果是正确的,因为如果在同一时刻有多个客户端在同时执行该段代码,那么就会出现多线程程序中经常出现的一种错误场景--竞态争用(racecondition)。比如,客户端A和B都在同一时刻读取了mykey的原有值,假设该值为10,此后两个客户端又均将该值加一后set回Redis服务器,这样就会导致mykey的结果为11,而不是我们认为的12。为了解决类似的问题,我们需要借助WATCH命令的帮助,见如下代码:
     WATCH mykey
     val = GET mykey
     val = val + 1
     MULTI
     SET mykey $val
     EXEC
     和此前代码不同的是,新代码在获取mykey的值之前先通过WATCH命令监控了该键,此后又将set命令包围在事务中,这样就可以有效的保证每个连接在执行EXEC之前,如果当前连接获取的mykey的值被其它连接的客户端修改,那么当前连接的EXEC命令将执行失败。这样调用者在判断返回值后就可以获悉val是否被重新设置成功。













以上是关于redis乐观锁(适用于秒杀系统)的主要内容,如果未能解决你的问题,请参考以下文章

Redis事务系列之三Redis乐观锁实现秒杀

Redis事务系列之三Redis乐观锁实现秒杀

优惠卷秒杀系统设计全局唯一ID生成,秒杀下单,分析解决库存超卖(乐观锁)实现一人一单秒杀业务(对用户id加锁)集群模式下并发问题

利用乐观锁及redis解决电商秒杀高并发基本逻辑

基于redis实现商品秒杀系统

Redis学习Redis分布式锁实现秒杀业务(乐观锁悲观锁)