本文主要介绍基于redis 实现商品秒杀功能。先来跟大家讲下大概思路。总体思路就是要减少对数据库的访问,尽可能将数据缓存到Redis缓存中,从缓存中获取数据。
系统初始化的时候将秒杀商品库存放入redis缓存
第二创建消息队列(这里为了方便,我直接使用redis队列来进行模拟操作)
第三 配置RedisTemplate序列化
下面创建一个接口,在这个接口中创建10000个线程来模拟用户商品抢购场景
这里使用到了redis api中的decrement操作,预先减轻用户抢购的数量,同时判断redis中的库存是否大于用户抢购数量,如果小于0,直接提示用户秒杀失败,否则秒杀成功,进入redis消息队列执行数据库建库存操作。
下面测试演示
初始化商品库存100,在测试一万并发量后,最终发现不会不会出现超卖问题。因为这里一万个并发,每个并发抢购10件商品。经过redis减库存之后,最后只会有10个线程去更新数据库。
注意:以上代码只是解决了库存超卖问题,实际功能还需要考虑很多业务场景。
如果您发现该资源为电子书等存在侵权的资源或对该资源描述不正确等,可点击“私信”按钮向作者进行反馈;如作者无回复可进行平台仲裁,我们会在第一时间进行处理!
加入交流群
请使用微信扫一扫!