一个二手闲置商城,订单与商品模块之间的交互问题

购物车与商品用户的交互问题:

​1.首先,分析问题的背景:

​当用户在商品的界面点击立即购买的时候,如果没有购物车,那么现有的架构是:

​直接调用api传输商品详情+卖家Id+买家ID,直接跳转到支付界面上,例如填写个人信息,填写地址......

​上述的方式对于购买流程而言,需要设计的只有:服务之间的同步,那么就引发了一个问题:当我用户点击立即购买的时候,需要直接将商品的状态进行锁定吗?如果锁定的话,那么锁定的时间是多少?如果不锁定的话,商品被别人买走了怎么办?假如锁定的话,会不会出现恶意购买?如果不锁定的话,库存问题如何解决?

这是我目前项目中出现的问题,以前的架构是:

​假如我点击立即购买的时候,则锁定了商品,此时这个订单处于待支付状态,这也出现了我朋友的实际在应用层面的黑盒测试的时候,出现了这个问题,其他朋友就无法正确的访问这个商品了,此时虽然支付时间回调是5分钟,但是这个过程等待十分久,假如很多人同时只点击购买不支付,或者别人只想看看呢?这就是一个bug了

​针对这个bug,我的想法是这样的:

​前端: 携带 商品ID、数量、用户ID 请求订单服务。订单服务 收到请求后,不会立即操作数据库。它会先去查询 商品服务 获取商品信息(价格、名称等),并检查缓存中的可预扣减库存是否充足。如果 Redis 中的 `product:stock:123` 的值大于购买数量,订单服务就在 Redis 中将库存减掉,并生成一个有时效性的临时订单,有效期是 10分钟,返回临时订单号,前端跳转到支付确认页面。这个页面上会有一个倒计时,提醒用户在规定时间内完成支付。

​另外,我在想,二手闲置商城,需要购物车模块吗?

​欢迎大家评论讨论
#牛客解忧铺##如果再来一次,你还会选择这个工作吗?##技术人##牛客创作赏金赛#
#业务讨论#
全部评论
b2c和c2c还是不太一样的,可能以后会添加一种混合模式,即平台自身的商品,此时这个商品库存则不是c2c的唯一库存模式了,这个也是后面很后面才会考虑的问题了
点赞 回复 分享
发布于 2025-06-09 19:23 广西

相关推荐

03-26 13:04
已编辑
电子科技大学 算法工程师
xiaowl:你这个简历“条目上”都比较有深度性,但是实际上面试官又没法很好的评估你是怎么达到很多看上去很厉害的结果的。要避免一些看上去很厉害的包装,比如高效的内存复用策略的表达,如果仅是简单的一些内存共享机制,而且面试上也没有深挖的空间,就不要这样表达。比如,工程化模式本质上可能就是定义了一些abstract class,那也就没特别多值得讲的内容。建议简历上应该侧重那些你花了大量时间和精力解决、研究的问题,不要过分追求“丰富”,而是关注在技术深入度、问题解决能力的表现上。
没有实习经历,还有机会进...
点赞 评论 收藏
分享
个人背景:学院二本计科专业 大二开始实习个人经历:安克创新 、理想汽车、字节跳动碎碎念:我做事只有三分钟热度。看到进了大厂的同学,我会羡慕,也会跟着努力上进;但遇到好看的小说,我又会放下手头的事沉迷其中,之前的坚持也就中断了。我有些自卑,总觉得自己学历和外貌都不够好。之前偶然在网上受到关注,我就喜欢上了上网,因为这里有很多人认可我。但我也很在意别人的评价,偶尔看到嘲讽的言论,会触发我的自卑情绪,让我感到愤怒。有时候我会强硬地回怼,有时候又会懦弱地选择无视。我也有虚荣心。不管是拿到安克、理想还是字节的机会,我在分享的时候都会带着这份心思。我会特意强调自己学历不好,是为了衬托出过程的艰难,以此显得自己更厉害。我知道,人往往会炫耀自己缺少的东西,来掩盖内心的空洞。我总想着走捷径,不太喜欢踏踏实实地做事。找实习的时候,我花了更多时间在研究面试技巧上,而不是提升专业能力。我会反复听面试录音分析技巧,看面试教程学习怎么和不同的面试官沟通,还会每天自言自语练习语言表达,同学都觉得我有点奇怪。我的实习生涯里,侥幸和运气占了很大一部分。我总在想,如果有一天我失去了这份幸运,这些特质可能会让我一蹶不振。ps: 很多人会问我学习路线和经验 但是就像我上面说的 我的实习过程靠的很多是关键节点的运气 技术上面我可能不如很多人  所以请大家理性求助和理性参考我的回答 附上我的投递记录
我的offer在哪里...:从去年看到现在,飞升哥就是榜样
我的求职进度条
点赞 评论 收藏
分享
评论
1
2
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务