使用 redis 减少 秒杀库存 超卖思路 (转)

 

由于数据库查询的及插入的操作 耗费的实际时间要耗费比redis 要多,

导致 多人查询时库存有,但是实际插入数据库时却超卖

redis 会有效的减少相关的延时,对于并发量相对较少的 可以一用

复制代码
复制代码
 1     public function buy($goods_id = 0){  
 2         if(!$goods_id){  
 3             die("商品不存在!");  
 4         }  
 5         $redis = new Redis();  
 6         $redis->connect('127.0.0.1',6379);  
 7         $stock = 0;  
 8         if(!$redis->get("gid".$goods_id)){  
 9             $stock = get_stock($goods_id); //从数据看获取实际库存  
10             $redis->set("gid".$goods_id,$stock);  
11         }else{  
12             $stock = $redis->get("gid".$goods_id);  
13         }  
14       
15         if($stock > 0){  
16             //逻辑操作 代码  
17             //coding here...  
18             set("gid".$goods_id,$stock-1);  
19         }else{  
20             die("已卖完!");  
21         }  
22     }  
复制代码
复制代码

 

转载自:https://www.cnblogs.com/zuochuang/p/7262399.html

 
分类: PHP
 
posted @   Kris-Q  阅读(5492)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
点击右上角即可分享
微信分享提示