Rumah  >  Artikel  >  pangkalan data  >  redis如何解决秒杀超卖问题

redis如何解决秒杀超卖问题

尚
asal
2019-07-05 16:16:129553semak imbas

redis如何解决秒杀超卖问题

首先,生成库存的计数量

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

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

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

测试:

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

1.jpg

更多Redis相关知识,请访问Redis使用教程栏目!

Atas ialah kandungan terperinci redis如何解决秒杀超卖问题. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn