redis 秒杀成功 mysql_如何使用Redis实现秒杀
如何使用Redis實(shí)現(xiàn)秒殺
發(fā)布時(shí)間:2020-07-15 14:33:30
來源:億速云
閱讀:150
作者:Leah
如何使用Redis實(shí)現(xiàn)秒殺?很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。
導(dǎo)語:秒殺想必大家都了解,在短時(shí)間內(nèi)請(qǐng)求訪問會(huì)激增,同時(shí)要保證不會(huì)超賣和數(shù)據(jù)的準(zhǔn)確,對(duì)于技術(shù)方面還是有些考驗(yàn)的。可惜的是,一直沒有機(jī)會(huì)在項(xiàng)目中實(shí)現(xiàn)。再看了一些資料后,打算實(shí)驗(yàn)下。以下代碼僅為測(cè)試所用,環(huán)境比較簡(jiǎn)單,請(qǐng)根據(jù)實(shí)際情況進(jìn)行修改。
創(chuàng)建秒殺隊(duì)列
在開始秒殺之前,先將商品放入隊(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 中看下
有 30 個(gè)商品 ID,數(shù)據(jù)正常。
秒殺
接下來是關(guān)鍵的一步,使用的是 Redis 的 lpop 命令獲取商品 ID,利用的是 Redis 的原子性。/**
* 秒殺
*/
public function buy()
{
// 隨機(jī)用戶名,無意義,僅做標(biāo)記
$username = Hash::make(now());
if ($goodsId = Redis::lpop('goods_list')) {
// 購(gòu)買成功
Redis::hset('buy_success', $goodsId, $username);
} else {
// 購(gòu)買失敗
Redis::incr('buy_fail');
}
}
如上,簡(jiǎn)化了代碼,購(gòu)買之后,成功與否只是做記錄。實(shí)際應(yīng)用中,當(dāng)然會(huì)更加復(fù)雜,但要注意的是,不要同步操作 Mysql。多說一句,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 次
執(zhí)行完成,速度并不快,并且還有 794 個(gè)訪問失敗。來看下數(shù)據(jù)是否正確吧。在頁面中打印 buy_success 值
30 個(gè)成功者。再來看下秒殺失敗的數(shù)量
不是一個(gè)準(zhǔn)確的數(shù)字,2165+30 是所有請(qǐng)求成功的數(shù)字,再加上失敗的 794 ,總數(shù)是 2989,依然不足 3000。
看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或相關(guān)文章,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝您對(duì)億速云的支持。
總結(jié)
以上是生活随笔為你收集整理的redis 秒杀成功 mysql_如何使用Redis实现秒杀的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: html converttopdf无法换
- 下一篇: 上行短信 写入mysql_7、上行短信处