Spring Boot + Redis 解决商品秒杀库存超卖,看这篇文章就够了

程序员私房菜

共 1159字,需浏览 3分钟

 ·

2020-06-17 23:21


今日 Java 干货

91f13dd1fbde053be9572884b3569dd7.webp刚刚发表


查看:15400回复:165

扫描下方二维码,后台回复 笔记,免费获取 10万字Springboot学习笔记

?长按上方二维码 2 秒回复「笔记」即可获取资料


作者:涛哥谈篮球

来源:toutiao.com/i6836611989607809548

问题描述

在众多抢购活动中,在有限的商品数量的限制下如何保证抢购到商品的用户数不能大于商品数量,也就是不能出现超卖的问题;还有就是抢购时会出现大量用户的访问,如何提高用户体验效果也是一个问题,也就是要解决秒杀系统的性能问题。本文主要介绍基于redis 实现商品秒杀功能。先来跟大家讲下大概思路。

总体思路就是要减少对数据库的访问,尽可能将数据缓存到Redis缓存中,从缓存中获取数据。

在系统初始化时,将商品的库存数量加载到Redis缓存中;接收到秒杀请求时,在Redis中进行预减库存,当Redis中的库存不足时,直接返回秒杀失败,否则继续进行第3步;将请求放入异步队列中,返回正在排队中;服务端异步队列将请求出队,出队成功的请求可以生成秒杀订单,减少数据库库存,返回秒杀订单详情。当后台订单创建成功之后可以通过websocket 向用户发送一个秒杀成功通知。前端以此来判断是否秒杀成功,秒杀成功则进入秒杀订单详情,否则秒杀失败。

下面直接上代码系统初始化的时候将秒杀商品库存放入redis缓存

7f9eec3fa6ab30d8d70a4a72998d19de.webp

第二创建消息队列(这里为了方便,我直接使用redis队列来进行模拟操作)

e39c7bb4af5f77c114a219a05ec1746f.webp

第三 配置RedisTemplate序列化

c7cc529e3336f6e0eb54f5bf751923d5.webp

下面创建一个接口,在这个接口中创建10000个线程来模拟用户商品抢购场景

a9f7d08a2c68808f6d4479f2cbe73f95.webp

f26f749ed342847545c11b6febc0411d.webp

这里使用到了redis api中的decrement操作,预先减轻用户抢购的数量,同时判断redis中的库存是否大于用户抢购数量,如果小于0,直接提示用户秒杀失败,否则秒杀成功,进入redis消息队列执行数据库建库存操作。以上操作注意保证redis缓存与数据库库存数据保持一致性。

bf9f474e50b4a26e78857d557c7b8ede.webp

下面测试演示

31a1cc6018d5f043777f860484a26ec8.webp

初始化商品库存100,在测试一万并发量后,最终发现不会不会出现超卖问题。因为这里一万个并发,每个并发抢购10件商品。经过redis减库存之后,最后只会有10个线程去更新数据库。


 

 

文末福利

免费分享一套我亲自写的10万字Springboot学习笔记(带完整目录)以及源码,下图是pdf版本的部分截图。

e1b3894dd042f4cc384f7f02b1fc605d.webp


 


获取方式:

扫描下方二维码,回复笔记

?长按上方二维码 2 秒回复「笔记」即可获取资料


希望大家拿去好好学习,如果觉得不错,也可以把文章分享给其他小伙伴,一起学习!


点赞是最大的支持 b8791d0004f9d22f3c10035a585a10ac.webp

浏览 35
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报