iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >怎么通过redis实现减库存的秒杀场景
  • 284
分享到

怎么通过redis实现减库存的秒杀场景

2023-06-30 18:06:03 284人浏览 独家记忆
摘要

这篇“怎么通过redis实现减库存的秒杀场景”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“怎么通过Redis实现减库存的秒杀

这篇“怎么通过redis实现减库存的秒杀场景”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“怎么通过Redis实现减库存的秒杀场景”文章吧。

Redis扣库存,主要目的是减少对数据库的访问,之前的减库存,直接访问数据库,读取库存,当高并发请求到来的时候,大量的读取数据有可能会导致数据库的崩溃。

使用思路:

  • 系统初始化的时候,将商品库存加载到Redis 缓存中保存。

  • 收到请求的时候,先在Redis中拿到该商品的库存值,进行库存预减,如果减完之后库存不足,直接返回逻辑Exception就不需要访问数据库再去减库存了,如果库存值正确,进行下一步。

  • 将请求入队,立即给前端返回一个值,表示正在排队中,然后进行秒杀逻辑,后端队列进行秒杀逻辑,前端轮询后端发来的请求,如果秒杀成功,返回秒杀,成功,不成功就返回失败。

第一步:系统初始化后就将所有商品库存放入缓存

@Overridepublic void afterPropertiesSet() throws Exception {    List<GoodsVo> goods = goodsService.getGoodsList();    if (goods == null) {        return;    }    for (GoodsVo goodsVo : goods) {        redisService.set(GoodsKey.getId(), goodsVo.getStockCount());        isOverMap.put(goodsVo.getId(), false);//先初始化 每个商品都是false 就是还有    }}

第二步: 预减库存从缓存中减库存

long stock = redisService.decr(GoodsKey.getGoodsStock, "" + goodsId);if (stock < 0) {    isOverMap.put(goodsId, true);//没有库存就设置 对应id 商品的map 为true    return Result.error(CodeMsg.MIAO_SHA_NO_STOCK);}

整体的逻辑如下:

先将所有数据读出来,初始化到缓存中,并以 stock + goodid 的形成存入Redis。

在秒杀的时候,先进行预减库存检测,从redis中,利用decr 减去对应商品的库存,如果库存小于0,说明此时 库存不足,则不需要访问数据库。直接抛出异常即可。
我们上面还使用到了isOverMap,这个是内存标记。

内存标记

由于接口优化很多基于Redis的缓存操作,当并发很高的时候,也会给Redis服务器带来很大的负担,如果可以减少对Redis服务器的访问,也可以达到的优化的效果。

于是,可以加一个内存map,标记对应商品的库存量是否还有,在访问Redis之前,在map中拿到对应商品的库存量标记,就可以不需要访问Redis 就可以判断没有库存了。

生成一个map,并在初始化的时候,将所有商品的id为键,标记false 存入map中。

private Map<Long, Boolean> isOverMap = new HashMap<Long, Boolean>();@Overridepublic void afterPropertiesSet() throws Exception {    List<GoodsVo> goods = goodsService.getGoodsList();    if (goods == null) {        return;    }    for (GoodsVo goodsVo : goods) {        redisService.set(GoodsKey.getGoodsStock, "" + goodsVo.getId(), goodsVo.getStockCount());        isOverMap.put(goodsVo.getId(), false);//先初始化 每个商品都是false 就是还有    }}
boolean isOver = isOverMap.get(goodsId);if (isOver) {     return Result.error(CodeMsg.MIAO_SHA_NO_STOCK);}if (stock < 0) {     isOverMap.put(goodsId, true);//没有库存就设置 对应id 商品的map 为true}

在预减库存之前,从map中取标记,若标记为false,说明库存

预减库存,当遇到库存不足的时候,将该商品的标记置为true,表示该商品的库存不足。这样,下面的所有请求,将被拦截,无需访问redis进行预减库存。

所以利用缓存的整体思路如下:

将商品的库存数据加载至内存,同时初始化内存标记,即把每个产品的id存放至map,都是初始化为false,在每次需要执行秒杀逻辑之前,在在内存标记中取值,如果仍有库存即map里返回的为false,则 执行秒杀逻辑,否则直接抛出异常。

同时扣减库存时,需要判断缓存中的库存数量是否仍然大于0,如果小于等于0,修改内存标记。

以上就是关于“怎么通过redis实现减库存的秒杀场景”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网精选频道。

--结束END--

本文标题: 怎么通过redis实现减库存的秒杀场景

本文链接: https://www.lsjlt.com/news/330633.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么通过redis实现减库存的秒杀场景
    这篇“怎么通过redis实现减库存的秒杀场景”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“怎么通过redis实现减库存的秒杀...
    99+
    2023-06-30
  • 如何通过redis减库存的秒杀场景实现
    目录使用思路:第一步:系统初始化后就将所有商品库存放入缓存第二步: 预减库存从缓存中减库存内存标记Redis扣库存,主要目的是减少对数据库的访问,之前的减库存,直接访问数据库,读取库...
    99+
    2024-04-02
  • redislua脚本实战秒杀和减库存的实现
    目录前言1.redisson介绍2. redis lua脚本编写与执行3.redis减库存lua脚本4.实战4.1 减库存逻辑4.2 压测前言 我们都知道redis是高性能高并发系统...
    99+
    2024-04-02
  • Redis分布式缓存与秒杀怎么实现
    本篇内容介绍了“Redis分布式缓存与秒杀怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、单点Redis的问题数据丢失问题Redi...
    99+
    2023-07-05
  • redis怎么实现秒杀功能
    在Redis中实现秒杀功能的一种常见方法是使用Redis的原子操作和事务来控制并发访问和更新库存数量。 以下是一个简单的秒杀功能的实...
    99+
    2024-04-02
  • thinkphp中怎么利用redis实现秒杀缓存功能
    thinkphp中怎么利用redis实现秒杀缓存功能,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1,安装redis,根据自己的php版本安装对应的redis扩...
    99+
    2023-06-19
  • Redis消息队列怎么实现秒杀
    要实现秒杀功能,可以使用Redis的消息队列来进行异步处理。下面是一种基本的实现方法:1. 准备工作:创建一个商品库存键值对,如"s...
    99+
    2023-10-11
    Redis
  • Redis实现秒杀的问题怎么解决
    本篇内容介绍了“Redis实现秒杀的问题怎么解决”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1、秒杀逻辑...
    99+
    2024-04-02
  • Go库存扣减怎么实现
    这篇文章主要介绍了Go库存扣减怎么实现的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Go库存扣减怎么实现文章都会有所收获,下面我们一起来看看吧。Go 库存扣减的几种实现方法这里使用了 grpc、proto、go...
    99+
    2023-06-26
  • redis lua脚本实战和减库存的实现是怎样的
    这篇文章给大家介绍redis lua脚本实战和减库存的实现是怎样的,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。前言我们都知道redis是高性能高并发系统必不可少的kv中间件,它以高性能,高并发著称,我们常常...
    99+
    2023-06-21
  • 怎么使用Go和Lua解决Redis秒杀中库存与超卖问题
    这篇文章主要介绍“怎么使用Go和Lua解决Redis秒杀中库存与超卖问题”,在日常操作中,相信很多人在怎么使用Go和Lua解决Redis秒杀中库存与超卖问题问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么使...
    99+
    2023-07-05
  • 怎么在redis中使用watch实现一个秒杀抢购功能
    怎么在redis中使用watch实现一个秒杀抢购功能?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。具体内容如下1、使用watch,采用乐观...
    99+
    2024-04-02
  • 如何使用Redis实现电商系统的库存扣减
    目录解决方案分析基于数据库单库存基于数据库多库存基于redis基于redis实现扣减库存的具体实现在日常开发中有很多地方都有类似扣减库存的操作,比如电商系统中的商品库存,抽奖系统中的...
    99+
    2024-04-02
  • Redis实现库存扣减的解决方案防止商品超卖
    目录Redis 如何实现库存扣减操作?如何防止商品被超卖?解决方案1. 使用mysql数据库2. 还是使用数据库3. 将库存放到redis使用redis的incrby特性来扣减库存。...
    99+
    2024-04-02
  • Redis分布式锁怎么实现及应用场景是什么
    本篇内容介绍了“Redis分布式锁怎么实现及应用场景是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!引言锁是开发过程中十分常见的工具,你...
    99+
    2023-06-29
  • SpringBoot中怎么通过整合Redis实现管道
    这篇文章给大家介绍SpringBoot中怎么通过整合Redis实现管道,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1. Redis 之管道(pipeline)执行一个Redis命令,Redis客户端和Redis服务器...
    99+
    2023-06-20
  • 怎么使用JS+Canvas实现雪花纷飞的场景
    这篇文章主要介绍“怎么使用JS+Canvas实现雪花纷飞的场景”,在日常操作中,相信很多人在怎么使用JS+Canvas实现雪花纷飞的场景问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么使用JS+Canvas...
    99+
    2023-07-04
  • SQL Server中怎么通过扩展存储过程实现数据库远程备份与恢复
    这篇文章将为大家详细讲解有关SQL Server中怎么通过扩展存储过程实现数据库远程备份与恢复,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。实现远程备份与恢...
    99+
    2024-04-02
  • Redis中的布隆过滤器怎么实现
    这篇文章主要介绍“Redis中的布隆过滤器怎么实现”,在日常操作中,相信很多人在Redis中的布隆过滤器怎么实现问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Redis中的布...
    99+
    2024-04-02
  • SpringBoot2 中怎么利用Redis数据库实现缓存管理
    SpringBoot2 中怎么利用Redis数据库实现缓存管理,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。一、Redis简介Spring Boot中除了对常用...
    99+
    2023-06-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作