redis watch 加 事务实现秒杀

Posted dongruiha

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了redis watch 加 事务实现秒杀相关的知识,希望对你有一定的参考价值。

<?php
 
//redis watch 加 事务实现秒杀
  
$redis = new redis();  
$result = $redis->connect(‘10.10.10.119‘, 6379);
 
$redis->watch("mywatchkey"); //必须先watch 后get

$mywatchkey = $redis->get("mywatchkey");
 
$rob_total = 100;   //抢购数量 
 
if($mywatchkey<$rob_total){
      
    $redis->multi();  
      
    //设置延迟,方便测试效果。  
    sleep(5);
    
 //插入抢购数据  
    $redis->hSet("mywatchlist", "user_id_".mt_rand(1, 9999),time());  
    $redis->set("mywatchkey", $mywatchkey+1);  
 
    $rob_result = $redis->exec();
 
    if($rob_result){  
        $mywatchlist = $redis->hGetAll("mywatchlist");  
        echo "抢购成功!<br/>";  
        echo "剩余数量:".($rob_total-$mywatchkey-1)."<br/>";  
        echo "用户列表:<pre>";  
        var_dump($mywatchlist);  
    }else{  
        echo "手气不好,再抢购!";exit;  
    }
 
}
 
?>





























以上是关于redis watch 加 事务实现秒杀的主要内容,如果未能解决你的问题,请参考以下文章

基于redis实现商品秒杀系统

高并发之商品秒杀系统

Redis篇:事务和lua脚本的使用

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

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

Redis 学习笔记总结