秒杀
库存限制和时间限制
1.提交秒杀商品申请,后台录入秒杀商品数据。
2.运营商审核
3.秒杀频道展示秒杀商品列表
4.打开秒杀列表进入到秒杀商品的详情页
5.开始秒杀—秒杀排队,下单,支付
6.秒杀成功但是没有支付成功,3min取消订单,关闭支付,恢复库存。
Redis缓存:
1.读取商品列表,放入redis
2.秒杀商品详情【静态化技术,redis缓存】
3.用户秒杀抢单都是在redis中进行,只有支付成功,订单信息以及库存信息才落地。
业务逻辑
将秒杀的商品查询出来,放到redis(怎么放让结果更加合理,使用hash),
多线程抢单过程
解决超卖问题
使用redis解决。
每个商品放在队列中有一个队列,有多少库存就有多少id,出售一个去除一个,队列清空时卖完
抢单成功后订单放入redis
代码实现
添加秒杀时间,设置队列防止超卖
列表页面展示
返回key,value进行抢购
检查排队和无效排队
商品入队操作
多线程异步抢单
若SeckillGoodsCountList能拿到值,表示未售罄,去redis拿商品并得到相关信息。创建order,放到redis缓存中
若商品售罄,清除redis内容。发送延时队列可以完成订单不支付,发送订单状态,到了时间监听。
监听订单信息后的操作。