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

项目使用Direct模式

思路:

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

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

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

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

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

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

猜你喜欢

转载自blog.csdn.net/weixin_39590058/article/details/88026930