我们知道大多数是基于数据版本(version)的记录机制实现的。即为数据增加一个版本标识,在基于数据库表的版本解决方案中,一般是通过为数据库表增加一个”version”字段来实现读取出数据时,将此版本号一同读出,之后更新时,对此版本号加1。此时,将提交数据的版本号与数据库表对应记录的当前版本号进行比对,如果提交的数据版本号大于数据库当前版本号,则予以更新,否则认为是过期数据。redis中可以使用watch命令会监视给定的key,当exec时候如果监视的key从调用watch后发生过变化,则整个事务会失败。也可以调用watch多次监视多个key。这样就可以对指定的key加乐观锁了。注意watch的key是对整个连接有效的,事务也一样。如果连接断开,监视和事务都会被自动清除。当然了exec,discard,unwatch命令都会清除连接中的所有监视。

  Redis中的事务(transaction)是一组命令的集合。事务同命令一样都是Redis最小的执行单位,一个事务中的命令要么都执行,要么都不执行。Redis事务的实现需要用到 MULTI 和 EXEC 两个命令,事务开始的时候先向Redis服务器发送 MULTI 命令,然后依次发送需要在本次事务中处理的命令,最后再发送 EXEC 命令表示事务命令结束。Redis的事务是下面4个命令来实现 :

1).multi,开启Redis的事务,置客户端为事务态。

2).exec,提交事务,执行从multi到此命令前的命令队列,置客户端为非事务态。

3).discard,取消事务,置客户端为非事务态。

4).watch,监视键值对,作用时如果事务提交exec时发现监视的监视对发生变化,事务将被取消。

乐观锁的实现: 
  乐观锁实现中的锁就是商品的键值对。使用watch方法监视商品键值对,如果事务提交exec时发现监视的键值对发生变化,事务将被取消。

       1. 乐观锁的实现,必须基于WATCH,然后利用redis的事务。

       2. WATCH生命周期,只是和事务关联的,一个事务执行完毕,相应的watch的生命周期即结束。

悲观锁实现: 
  悲观锁中的锁是一个唯一标识的锁lockKey和该锁的过期时间。首先确定缓存中有数据,然后在拿数据(商品数目改动)之前先获取到锁,之后对商品数目进行减一操作,操作完成释放锁,一个秒杀操作完成。这个锁是基于redis的setNX操作实现的阻塞式分布式锁。

 这里我没有写太多代码的实例。大家可以在其他的文章看到类似代码。这里我只说一下原理和理论性的知识。