Redis實(shí)現(xiàn)秒殺的方法介紹(附代碼)

本篇文章給大家?guī)?lái)的內(nèi)容是關(guān)于redis實(shí)現(xiàn)秒殺的方法介紹(附代碼),有一定的參考價(jià)值,有需要的朋友可以參考一下,希望對(duì)你有所幫助。

導(dǎo)語(yǔ):秒殺想必大家都了解,在短時(shí)間內(nèi)請(qǐng)求訪問(wèn)會(huì)激增,同時(shí)要保證不會(huì)超賣(mài)和數(shù)據(jù)的準(zhǔn)確,對(duì)于技術(shù)方面還是有些考驗(yàn)的??上У氖?,一直沒(méi)有機(jī)會(huì)在項(xiàng)目中實(shí)現(xiàn)。再看了一些資料后,打算實(shí)驗(yàn)下。以下代碼僅為測(cè)試所用,環(huán)境比較簡(jiǎn)單,請(qǐng)根據(jù)實(shí)際情況進(jìn)行修改。

創(chuàng)建秒殺隊(duì)列

在開(kāi)始秒殺之前,先將商品放入隊(duì)列中,如下

/**      * 創(chuàng)建秒殺列表      */     public function createList()     {         $count = 30;         $redisKey = 'goods_list';          for ($i = 1; $i <= $count; $i++) {              // 測(cè)試用,防止數(shù)據(jù)錯(cuò)誤             if (Redis::llen($redisKey) >= $count) {                 break;             }              Redis::rpush($redisKey, $i);         }     }

執(zhí)行完后,在 Redis 中看下

Redis實(shí)現(xiàn)秒殺的方法介紹(附代碼)有 30 個(gè)商品 ID,數(shù)據(jù)正常。

秒殺

接下來(lái)是關(guān)鍵的一步,使用的是 Redis 的 lpop 命令獲取商品 ID,利用的是 Redis 的原子性。

/**      * 秒殺      */     public function buy()     {         // 隨機(jī)用戶名,無(wú)意義,僅做標(biāo)記         $username = Hash::make(now());          if ($goodsId = Redis::lpop('goods_list')) {             // 購(gòu)買(mǎi)成功             Redis::hset('buy_success', $goodsId, $username);         } else {             // 購(gòu)買(mǎi)失敗             Redis::incr('buy_fail');         }     }

如上,簡(jiǎn)化了代碼,購(gòu)買(mǎi)之后,成功與否只是做記錄。實(shí)際應(yīng)用中,當(dāng)然會(huì)更加復(fù)雜,但要注意的是,不要同步操作 mysql。多說(shuō)一句,Hash:make(now()) 即使值相同,也不會(huì)生成相同的數(shù)據(jù),參考這里。

測(cè)試

最后就是進(jìn)行測(cè)試了,使用 ab 測(cè)試,執(zhí)行 ab -c 300 -n 3000 http://localhost/buy/ ,上述命令的意思是 300 并發(fā),共請(qǐng)求 3000 次

Redis實(shí)現(xiàn)秒殺的方法介紹(附代碼)

執(zhí)行完成,速度并不快,并且還有 794 個(gè)訪問(wèn)失敗。來(lái)看下數(shù)據(jù)是否正確吧。在頁(yè)面中打印 buy_success 值

Redis實(shí)現(xiàn)秒殺的方法介紹(附代碼)

30 個(gè)成功者。再來(lái)看下秒殺失敗的數(shù)量

Redis實(shí)現(xiàn)秒殺的方法介紹(附代碼)不是一個(gè)準(zhǔn)確的數(shù)字,2165+30 是所有請(qǐng)求成功的數(shù)字,再加上失敗的 794 ,總數(shù)是 2989,依然不足 3000。

結(jié)語(yǔ)

上述測(cè)試有不足的地方,相應(yīng)速度慢、請(qǐng)求失敗、失敗計(jì)數(shù)不準(zhǔn)確??磥?lái)有很多要優(yōu)化的地方,不止是代碼層。測(cè)試的時(shí)候忘記將訪問(wèn)記錄入庫(kù)關(guān)掉,應(yīng)該是有些影響。
好的方面是秒殺成功的數(shù)量是準(zhǔn)確的,沒(méi)有超賣(mài)?!鞠嚓P(guān)推薦:Redis教程

? 版權(quán)聲明
THE END
喜歡就支持一下吧
點(diǎn)贊11 分享