项目中使用到了redis,rabbitmq来实现秒杀,有一个点不太清楚:在使用了redis decrement来预减库存后,如果库存没有小于0,则将下单请求发送到rabbitmq。好奇的点在于decrement的操作是原子的,那么进入到rabbitmq的消息也就是库存的数量。这么来看如果库存不是很多数据库的压力也就不是很大,这种情况下是不是也不太需要rabbitmq呢?或者说rabbitmq是不是适用于库存数量相对较大,所以用来减少数据库压力并且也能让用户的体验感更好(不需要等待下单的过程)?
1条回答 默认 最新
- 林晓风 2022-07-31 16:33关注
用rabbitmq的原因是要解耦,跟库存量大小没关系,试想一下,同时成千上万个人要秒杀同一件商品,你的这个接口即使是原子操作,即使你加了锁,你是不是也要保证你这个接口的快速响应哇,说白了就是这个接口要快,用rabbitmq不仅可以解耦,还可以削峰,降流。
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥170 如图所示配置eNSP
- ¥20 docker里部署springboot项目,访问不到扬声器
- ¥15 netty整合springboot之后自动重连失效
- ¥15 悬赏!微信开发者工具报错,求帮改
- ¥20 wireshark抓不到vlan
- ¥20 关于#stm32#的问题:需要指导自动酸碱滴定仪的原理图程序代码及仿真
- ¥20 设计一款异域新娘的视频相亲软件需要哪些技术支持
- ¥15 stata安慰剂检验作图但是真实值不出现在图上
- ¥15 c程序不知道为什么得不到结果
- ¥15 键盘指令混乱情况下的启动盘系统重装