接口优化--Rabbit MQ异步下单

项目使用Direct模式

思路:

1. 当确认秒杀时,(库存充足,且无重复秒杀)将秒杀请求需要消息入队,同时给前段返回一个code(0)

  前端接收到数据后,显示排队中。

2. 后端Rabbit MQ监听秒杀queue的这名字的通道,如果有消息过来,获取传入的信息,执行真正的秒杀之前,要判断数据库的库存,之前判断的是Redis的库存,判断是否重复秒杀,然后执行miaoshaService

3. 此时,在前端根据商品id轮询请求getResult,如果请求到的商品生成了商品订单(userid, goodsid到数据库里查),说明秒杀成功

前端会根据后端返回的值来判断 是秒杀成功还是继续轮询 还是秒杀失败

三种: -1 秒杀失败;  0 排队中,继续轮询 ; >0 返回的是商品id,说明秒杀成功

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值