电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術(shù)文章
文章詳情頁

PHP+Redis鏈表解決高并發(fā)下商品超賣問題(實(shí)現(xiàn)原理及步驟)

瀏覽:140日期:2022-09-09 14:08:20

上一篇文章聊了一下使用Redis事務(wù)來解決高并發(fā)商品超賣問題,今天我們來聊一下使用Redis鏈表來解決高并發(fā)商品超賣問題。

實(shí)現(xiàn)原理

使用redis鏈表來做,因?yàn)閜op操作是原子的,即使有很多用戶同時(shí)到達(dá),也是依次執(zhí)行,推薦使用。

實(shí)現(xiàn)步驟

第一步,先將商品庫存入隊(duì)列

/** * 添加商品數(shù)量到商品隊(duì)列 * @param int $couponId 優(yōu)惠券ID */function addCoupons($couponId){ //1.初始化Redis連接 $redis = new Redis(); if (!$redis->connect(’127.0.0.1’, 6379)) { trigger_error(’Redis連接出錯(cuò)!!!’, E_USER_ERROR); } else { echo ’連接正常<br>’; } //根據(jù)優(yōu)惠券ID從數(shù)據(jù)庫中查詢?cè)搩?yōu)惠券的庫存量 //$sql = 'select id, stock from coupon where id = {$couponId}'; $stock = 10; //假設(shè)10就是我們從數(shù)據(jù)庫中查詢出的該優(yōu)惠券在數(shù)據(jù)庫中的庫存量 //我們現(xiàn)在將這10個(gè)庫存放入到以該商品ID為key的redis鏈表中,有幾件庫存,就存入多少次1,鏈表長度代表商品庫存數(shù) for($i = 0; $i < $stock; $i++) { $redis->lPush('secKill:'.$couponId.':stock', 1); } $redis->close();}$couponId = 11211;addCoupons($couponId);

我們調(diào)用該方法,然后查看redis,鏈表中已經(jīng)添加了10個(gè)元素

PHP+Redis鏈表解決高并發(fā)下商品超賣問題(實(shí)現(xiàn)原理及步驟)

第二步,搶購開始,設(shè)置庫存的緩存周期

這一步根據(jù)自己的業(yè)務(wù)來定,如果業(yè)務(wù)規(guī)定,這個(gè)優(yōu)惠券就放出2分鐘給用戶搶,那么就通過expire()方法給鏈表設(shè)置一個(gè)有效期,即使是在有效期內(nèi)沒有搶完仍然有庫存也不讓用戶搶了(由于我們公司業(yè)務(wù)不對(duì)優(yōu)惠券搶券設(shè)置有效期,所以這一步我不需要做)

//設(shè)置鏈表有效期是兩分鐘$redis->expire(’key’, 120);

第三步,客戶端執(zhí)行瞬時(shí)搶購操作

/** * 搶優(yōu)惠券(秒殺) * @param int $couponId 商品ID * @param int $uid 用戶ID * @return bool */function secKill($couponId, $uid){ //1.初始化Redis連接 $redis = new Redis(); if (!$redis->connect(’127.0.0.1’, 6379)) { trigger_error(’Redis連接出錯(cuò)!!!’, E_USER_ERROR); } else { echo ’連接正常<br>’; } //將已經(jīng)成功搶購的用戶添加到該以該商品ID為key的集合(set)中 //如果用戶已經(jīng)在集合中,說明用戶已經(jīng)成功秒殺過一次了,不允許再次參與秒殺 if ($redis->sIsMember(’secKill:’.$couponId.’:uid’, $uid)) { echo ’秒殺失敗’; return false; } //秒殺商品的庫存key $key = ’secKill:’.$couponId.’:stock’; //從以該優(yōu)惠券ID為key的鏈表中彈出一個(gè)值,如果有值,證明優(yōu)惠券還有庫存 $isSockNotEmpty = $redis->lPop($key); //判斷庫存,如果庫存大于0,則減庫存,將該成功秒殺用戶加入哈希表,如果小于等于0,秒殺結(jié)束 if ($isSockNotEmpty != 1) { echo ’秒殺已結(jié)束’; return false; } //搶券成功,將優(yōu)惠券ID和UID放入到隊(duì)列中,由一個(gè)單獨(dú)的進(jìn)程隊(duì)列來消費(fèi)隊(duì)列里的數(shù)據(jù),向用戶推送搶到的優(yōu)惠券 $redis->lPush(’couponOrder’, $couponId.’+’.$uid); //將成功搶券的用戶記錄到集合中,防止被已搶過的用戶再次秒殺 $redis->sAdd(’secKill:’.$couponId.’:uid’, $uid); $redis->close(); return true;}$couponId = 11211;$uid = mt_rand(1, 100);secKill($couponId, $uid);

第四步,將成功秒殺的用戶入數(shù)據(jù)庫持久化數(shù)據(jù),對(duì)于并發(fā)量不是很大的搶購,我們可以在第三步成功搶購后直接將信息寫入數(shù)據(jù)庫,對(duì)于并發(fā)量比較大的可以放入RabbitMQ消息隊(duì)列中消費(fèi)(推薦使用RabbitMQ隊(duì)列而不是redis是因?yàn)镽abbitMQ可以保證消息百分之百的被消費(fèi),而redis就相對(duì)沒有那么穩(wěn)定與可靠)

//此處代碼省略//根據(jù)自己的業(yè)務(wù)場(chǎng)景看看是入數(shù)據(jù)庫還是放入rabbitMQ消息隊(duì)列中消費(fèi)

現(xiàn)在我們使用ab工具模擬高并發(fā)下的搶券行為(2000次請(qǐng)求數(shù),100并發(fā)量)

ab -n 2000 -c 100 www.test.com/

然后我們通過Redis Desktop Manager來查看Redis的結(jié)果

同樣的,couponOrder隊(duì)列里已經(jīng)有了10份包含用戶uid和優(yōu)惠券id的信息了,這些信息可以由隊(duì)列消費(fèi)。

PHP+Redis鏈表解決高并發(fā)下商品超賣問題(實(shí)現(xiàn)原理及步驟)

同時(shí),用戶搶券集合里也保存了10個(gè)用戶的UID信息。

PHP+Redis鏈表解決高并發(fā)下商品超賣問題(實(shí)現(xiàn)原理及步驟)

到此這篇關(guān)于PHP+Redis鏈表解決高并發(fā)下商品超賣問題(實(shí)現(xiàn)原理及步驟)的文章就介紹到這了,更多相關(guān)php redis解決高并發(fā)下商品超賣內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: PHP
相關(guān)文章:
主站蜘蛛池模板: 河南砖机首页-全自动液压免烧砖机,小型砌块水泥砖机厂家[十年老厂] | 太原装修公司_山西整装家装设计_太原室内装潢软装_肖邦家居 | 缓蚀除垢剂_循环水阻垢剂_反渗透锅炉阻垢剂_有机硫化物-郑州威大水处理材料有限公司 | 快速门厂家-快速卷帘门-工业快速门-硬质快速门-西朗门业 | 英国雷迪地下管线探测仪-雷迪RD8100管线仪-多功能数字听漏仪-北京迪瑞进创科技有限公司 | 南昌旅行社_南昌国际旅行社_南昌国旅在线 | 混合反应量热仪-高温高压量热仪-微机差热分析仪DTA|凯璞百科 | 广州展览制作|展台制作工厂|展览设计制作|展览展示制作|搭建制作公司 | 滚筒烘干机_转筒烘干机_滚筒干燥机_转筒干燥机_回转烘干机_回转干燥机-设备生产厂家 | 奥因-光触媒除甲醛公司-除甲醛加盟公司十大品牌 | _网名词典_网名大全_qq网名_情侣网名_个性网名 | 风淋室生产厂家报价_传递窗|送风口|臭氧机|FFU-山东盛之源净化设备 | 湖南印刷厂|长沙印刷公司|画册印刷|挂历印刷|台历印刷|杂志印刷-乐成印刷 | 北京康百特科技有限公司-分子蒸馏-短程分子蒸馏设备-实验室分子蒸馏设备 | 哈尔滨治「失眠/抑郁/焦虑症/精神心理」专科医院排行榜-京科脑康免费咨询 一对一诊疗 | 全自动翻转振荡器-浸出式水平振荡器厂家-土壤干燥箱价格-常州普天仪器 | 高低温老化试验机-步入式/低温恒温恒湿试验机-百科 | 数控走心机-走心机价格-双主轴走心机-宝宇百科 | 长沙中央空调维修,中央空调清洗维保,空气能热水工程,价格,公司就找维小保-湖南维小保环保科技有限公司 | 密集架-手摇-智能-移动-价格_内蒙古档案密集架生产厂家 | 杭州货架订做_组合货架公司_货位式货架_贯通式_重型仓储_工厂货架_货架销售厂家_杭州永诚货架有限公司 | 四川实木门_成都实木门 - 蓬溪聚成门业有限公司 | 玉米深加工设备-玉米深加工机械-新型玉米工机械生产厂家-河南粮院机械制造有限公司 | 校服厂家,英伦校服定做工厂,园服生产定制厂商-东莞市艾咪天使校服 | 湖南教师资格网-湖南教师资格证考试网| 水性绝缘漆_凡立水_绝缘漆树脂_环保绝缘漆-深圳维特利环保材料有限公司 | 医院专用门厂家报价-医用病房门尺寸大全-抗菌木门品牌推荐 | 旋振筛|圆形摇摆筛|直线振动筛|滚筒筛|压榨机|河南天众机械设备有限公司 | 幂简集成 - 品种超全的API接口平台, 一站搜索、试用、集成国内外API接口 | 合肥汽车充电桩_安徽充电桩_电动交流充电桩厂家_安徽科帝新能源科技有限公司 | 二手光谱仪维修-德国OBLF光谱仪|进口斯派克光谱仪-热电ARL光谱仪-意大利GNR光谱仪-永晖检测 | 家德利门业,家居安全门,别墅大门 - 安徽家德利门业有限公司 | 制冷采购电子商务平台——制冷大市场| 蓝米云-专注于高性价比香港/美国VPS云服务器及海外公益型免费虚拟主机 | R507制冷剂,R22/R152a制冷剂厂家-浙江瀚凯制冷科技有限公司 | 美国PARKER齿轮泵,美国PARKER柱塞泵,美国PARKER叶片泵,美国PARKER电磁阀,美国PARKER比例阀-上海维特锐实业发展有限公司二部 | 水成膜泡沫灭火剂_氟蛋白泡沫液_河南新乡骏华消防科技厂家 | 便携式XPDM露点仪-在线式防爆露点仪-增强型烟气分析仪-约克仪器 冰雕-冰雪世界-大型冰雕展制作公司-赛北冰雕官网 | 一氧化氮泄露报警器,二甲苯浓度超标报警器-郑州汇瑞埔电子技术有限公司 | 冷却塔风机厂家_静音冷却塔风机_冷却塔电机维修更换维修-广东特菱节能空调设备有限公司 | 雾度仪_雾度计_透光率雾度仪价格-三恩时(3nh)光电雾度仪厂家 |