redis电商秒杀设计

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: redis电商秒杀设计

redis电商秒杀设计

@TOC


前言

在电商业务中,我们经常会遇到秒杀的业务情况,我们如何做到高成功抢购率以及实现不超卖的情况。
对于这种涉及到高并发的业务,我们通常会使用nosql去做处理。等到逻辑处理成功后才写库。


一、实现方式一

我们创建一个redis key值 为stock。库存为100。每次进入下单逻辑时,判断当前库存是否已经卖空。卖空直接return,同时设置一个是否正在处理下单逻辑的key值,如果有正在处理的订单,直接抛出异常,抢购失败。这样操作的弊端就是同一时刻只能处理一笔订单,抢购失败率会很高。

public function setStock1(){
        $redis =RedisHandler::getInstance();
        $redis->set("stock", 100);
    }

    public function placeOrder1(){
        $redis =RedisHandler::getInstance();
        $is_over = $redis->get("is_over");

        if($is_over == 1){
            echo "商品已售空";
            return;
        }
        $is_selling = $redis->get("is_selling");
        if($is_selling == 1){
            echo "抢购失败";
            return;
        }
        $redis->set("is_selling", 1);
        $new_stock = $redis->incre("stock", -1);
        echo "当前剩余库存:".$new_stock;
        sleep(1);
        if($new_stock <= 0){
            echo "商品已售空";
            $redis->set("is_over", 1);
        }else{
            //剩余库存
           $stock = $redis->get("stock");
           file_put_contents("a.txt", $stock."\r\n", FILE_APPEND);
           $redis->set("is_selling", 0);
        }
    }

二、实现方式二

使用redis队列来做。我们将需要抢购商品ID用队列的方式写入redis。然后下单时 每次重redis里面rPop弹出商品ID来进行业务处理。如果队列为空。提示抢购失败,库存卖完。这样就保证抢购成功率比较高,不会出现超卖的情况


public function setStock2(){
        $redis =RedisHandler::getInstance();
        for($i = 0; $i<100; $i++){
            $redis->rPush("stock", 1);
        }
    }

    public function placeOrder2(){
        $redis =RedisHandler::getInstance();
        $res = $redis->rPop("stock");
        if(!empty($res)){
            $stock = $redis->llen("stock");
            file_put_contents("a.txt", $stock."\r\n", FILE_APPEND);
            $redis->set("is_selling", 0);
        }else{
            echo "商品已售空";
            return;
        }
    }

总结

并不只是有上述方案可以实现秒杀业务,具体业务情况需要具体分析。
上面还有很多的附属业务的逻辑没有实现。比如支付问题,用户取消抢购成功的商品问题。

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
7月前
|
缓存 NoSQL 关系型数据库
亿级电商流量,高并发下Redis与MySQL的数据一致性如何保证
你们有多少人是被面试官问到过Redis和MySQL的数据一致性如何保证的? 你们是否考虑过在高并发场景下,Redis与MySQL的同步会有哪些问题?该如何解决? 本篇文章会带大家详细了解,让你知其然,知其所以然,吊打面试官。
521 0
亿级电商流量,高并发下Redis与MySQL的数据一致性如何保证
|
7月前
|
缓存 监控 NoSQL
Redis - 在电商购物车场景下的实战分析
Redis - 在电商购物车场景下的实战分析
487 0
|
NoSQL Redis
114分布式电商项目 - Redis集群(节点增加删除)
114分布式电商项目 - Redis集群(节点增加删除)
58 1
|
NoSQL Redis 数据库
淘东电商项目(21) -Redis如何与数据库状态保持一致?
淘东电商项目(21) -Redis如何与数据库状态保持一致?
58 0
|
存储 缓存 NoSQL
116分布式电商项目 - Redis集群(内存不足的问题)
116分布式电商项目 - Redis集群(内存不足的问题)
227 0
|
NoSQL Redis 数据库
115分布式电商项目 - Redis集群(故障转移)
115分布式电商项目 - Redis集群(故障转移)
69 0
|
NoSQL 算法 Redis
113分布式电商项目 - Redis集群(插槽)
113分布式电商项目 - Redis集群(插槽)
66 0
|
NoSQL Java Redis
112分布式电商项目 - Redis集群(创建)
112分布式电商项目 - Redis集群(创建)
75 0
|
监控 NoSQL 数据库
111分布式电商项目 - Redis集群(哨兵)
111分布式电商项目 - Redis集群(哨兵)
68 0
|
存储 缓存 NoSQL
110分布式电商项目 - Redis集群(主从复制)
110分布式电商项目 - Redis集群(主从复制)
77 0