开发者社区> 问答> 正文

[@徐雷frank][¥20]购物车防止超卖

已解决

一般怎么能有效的实现,保证系统安全

展开
收起
张文s 2018-11-29 20:39:41 2636 0
2 条回答
写回答
取消 提交回答
  • 1.阿里云大学讲师,主讲《微服务Spring Cloud设计与开发实战》《MongoDB高级实战》等课程 2.MongoDB中文社区专家 3.《MongoDB实战》第2版译者 5.吉林大学计算机科学学士、上海交通大学硕士
    采纳回答

    一般的做法2种做法:如果严格防止超卖,说白了必须有数据一致性的问题,而且是强一致性。
    目前如果要做到强一致性,可以有几种方式。
    1、如果系统并发不高,可以考虑使用数据库,比如MySQL的分布式事务,每个商品都有余额,用户提交订单的时候加锁,严格判断剩余数量,在允许下单。
    2、如果系统有高并发的要求,可以考虑使用Redis缓存,缓存商品的剩余数量,借助Redis的分布式锁,实现全局剩余商品数量的互斥修改,并在下单的时候判断购买数量和剩余数量。
    3、现在决大多数中国的电商系统都是放弃超卖的设置的,比如淘宝的许多店铺,还有苹果小米的新品发布抢购。这些都是允许超卖,因为只要用户付钱,就可以下单给工厂生产了。除非特殊需求,一般不会实际采用落地的超卖限制策略。

    2019-07-17 23:17:15
    赞同 展开评论 打赏
  • 这个问题比较大也比较宽泛; 一般正常的业态做法是,提供一个系统专门用来做资源的查询和扣减,比如总共有500的容量,那么一个用户下单后,就减1;当用户下单未付款后,订单自动关闭,并回补资源;

    这种做法是考虑没有恶意用户竞拍的情况,如果有恶意用户竞拍,那么可能还会相应的在安全策略上备战,例如防黄牛等。

    2019-07-17 23:17:15
    赞同 展开评论 打赏
问答分类:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载