温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

解决redis秒杀超卖的问题

发布时间:2020-08-25 10:19:22 来源:亿速云 阅读:152 作者:小新 栏目:关系型数据库

小编给大家分享一下解决redis秒杀超卖的问题,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!

解决redis秒杀超卖的问题

首先,生成库存的计数量

 public function kucun()
    {
        //有十个库存
        $count=10;
        //添加到redis list中
        for($i=0;$i<$count;$i++){
            Predis::getInstance()->lpush('kucun',111111111);
        }
        self::dd(Predis::getInstance()->lrange('kucun',0,-1));
    }

完后利用redis的lpop或rpop对list进行裁剪,之前采用llen或incr的方式对数据进行判断,都会出现超卖的现象,所以这里使用lpop的逻辑解决了超卖的问题

 public function ru()
    {   
        //判断计数器
        if (Predis::getInstance()->lpop('kucun')) {
            $user=User::where('user_id',1082)->find();
            //存入会员id
            Predis::getInstance()->lpush('user',$user['user_id']);
            //计数器累计加1
            // Predis::getInstance()->incr('number');
            echo '加入秒杀成功';exit();
        }else{
            echo '活动截至';
            exit();
        }
    }

测试:

ab -r -n 1000 -c 1000  http://149.28.16.212/index/index/ru

解决redis秒杀超卖的问题

看完了这篇文章,相信你对解决redis秒杀超卖的问题有了一定的了解,想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI