php+redis实现高并发抢购的思路

//把所有用户都插入到这个队列中
$wait_key = "user_wait:2";

//真正抢到的用户信息队列
$user_key = "user:1";

//库存队列
$store_key = "goods_store:1";

$result =$redis->hset($wait_key, $user_id, $user_id);  //插入用户id
    if($result)
    {
        $count = $redis->lpop($store_key);   //关键   控制每次操作都是以原子方式进行,只能进去一个
        if (!$count)
            echo '已经抢光了哦'.$user_id;
        else
        {
            $result =$redis->hset($user_key, $user_id, $user_id);
            echo '恭喜您!抢到了哦'.$user_id;
        }
    }

这段代码的思路是一开始定义两个hash表的字段,一个wait_key(参加抢购活动用户的id队列),另一个user_key(最终抢购成功用户的id队列)。然后把参加活动用户的userid存到wait_key队列里,键名键值都是$user_id(防止同一用户可以抢到多次),然后每抢到一个,从库存队列去除一个库存(这样就避免在高并发情况下发生库存和抢到数不一致的情况),再往user_key里插入userid。

 

 

 

 

以上代码来自该博客:https://blog.csdn.net/qq_33862778/article/details/80651703

展开阅读全文

没有更多推荐了,返回首页