redis的watch multi exec 方法实现秒杀抢购。优点:使用了乐观锁没有锁的等待,比队列方式减少了大量的内存消耗。 watch 监视一个或多个key,如果在事务执行之前这个(或这些)key被其他命令所改动,那么事务将被打断. $redis = new redis(); $result = $redis->connect('127.0.0.1',6379); $getnum = $redis->get('getnum');//已抢数量 $num = 100;//抢购总数量 if($getnum < $num){ $redis->watch('getnum');//监听key $redis->multi();//开启事务 //插入抢购数据 $redis->hSet("userList",'user_id_'.mt_rand(1,999),time()); $redis->set("getnum",$getnum+1);//抢购到+1 $robResult = $redis->exec();//执行事务 if ($robResult) { echo "抢购成功!<br/>"; echo "剩余数量:" . ($num - ($redis->get("getnum"))) . "<br/>"; echo "用户列表:<pre>"; var_dump($redis->hGetAll("userList")); } else { echo "手气不好,再抢购!"; exit; } }else{ echo "已售罄"; exit; }