在双 11 活动中天猫、淘宝网的超卖问题是如何产生的,可以认为是系统bug吗?

这会导致淘宝的双11活动卖出的金额191亿元很水啊
情况是这样的吗?而且大多发生在零点10分以内的?
当商家的存货趋近于0的时候,大量买家共同买入,当其中交易完成时,存货减1。如果这时存货数量到达0了,可还是有大量买家没有完成付款,从而生成超卖的订单了?

子柳,淘宝打杂的 码农

有一个CAP理论,扩展性、一致性、可用性和成本之间形成了相互制约的关系,可以理解成下图的三角形边长是收益、面积是成本,如果三个边都很长的话,成本是最大的。

在双十一这种最极端的场景下,要满足三个条件,成本更是高到无法承受。那我们缩小哪一条边长呢?可用性不能缺(不能宕机)、扩展性不能缺(要支持大规模的并发访问),只能牺牲一部分一致性了。这里采用异步通知、分布式事务等操作,来保证数据尽可能多的“最终一致”,但不可避免的会产生少量数据的不一致,这是在计划中可以容忍的。

另外还有一个业务方面的逻辑问题,这可能比技术方面出现超卖的概率更加大一些。
需要解释一下交易减库存的两种方式:
一,拍下减库存
描述:下单之后,商品的库存就减一,减库存失败 下单就失败,然后再去付款
问题:恶拍,恶人会把卖家的商品都拍光,商品下架了,然后不付款
二,付款减库存
描述:下单之后不立即减库存,跳转到支付宝付款,淘宝接收到付款成功消息后,才去减商品库存
问题:超卖,热销商品尤其是秒杀商品,同时会有n多人同时付款成功,然后去减库存时,发现库存不够减了

最后,也不排除个别卖家借这个机会来推卸责任的可能性。

岳天,互联网从业者,挨踢农民工,半码农

技术方面上面@子柳已经说的很明确了,超卖再交易量很大的情况下,出于对可用性和扩展性的需要,严格控制一致性成本无法满足,所以超卖还是有小部分。
下面从影响方面说说,首先,无论国内国外的网站都有超卖的情况发生,像现在正在进行的 黑色星期五,很多商品都有超卖,而国内外网站处理超卖大部分采取 “砍单”(砍单不一定全部是因为超卖),作为海淘一族,大部分已经形成概念“低价商品砍单时正常,不砍单是走运。”,亚马逊比较少砍单,也是因为其系统支持强大,较少发生超卖,京东等B2C也有超卖砍单情况。

此次天猫居然没有像 “团购宝事件”那样 全部进行退款砍单,而是进行了 30%的补偿,也是非常不错的。
应该可以预见造成的影响 是正面大于负面。

然后说一说一致性的问题,所有网站里,一致性要求最高的当属金融类网站,再具体点就是银行的交易系统。
有知道关于银行系统的知友可以讲一讲。
刚研究了下 银行业的一些资料,发现 实时的转账汇款有个20秒的概念,分2部分,一是发起交易确认付款,而是返回交易回执,交易才算完成。没有返回交易回执,则认为汇款失败,钱退回来。
淘宝的交易系统应该借鉴这样的操作,订单下后确认付款,同时确认库存,一旦发现超卖,即刻显示付款失败。
不要等到过了好几天才告诉别人,超卖了,货发不了,很伤人的。

张磊,学生浅薄,望诸师雅正。。。

可以从产品和运营两个角度,同步操作改善这个问题。
但是在产品角度上,需要评估投入产出比,如果投入产出比较低、那么不一定会得到执行。

一、产品角度:混合减库存方案
1.设立一个库存数阙值,比如50件。
--达到阙值之前,采用付款减库存的方案。
--达到阙值之后,自动转为拍下减库存的方案。
2.当然这个阙值需要根据并发订单数、“下单未付款”状态单数、总库存数等参数(也许还有其他参数)进行配置。
--在平时,并发订单数可能只是2件,平均会有最多10单左右处于“已下单但未付款”的状态。那么,这个阙值设为10件(或者12件?还没深入思考)。
--在促销时,并发订单数可能达到50,同时处于“下单未付款”状态的可能达到500单,那么这个阙值就可以考虑设为500件。
3.考虑到商品数量、高并发下系统的响应速度等因素,这个阙值可能还要再上调一部分比例,比如10%。
4.如果这个阙值可以自动调整,那就更完善了。但是在大数据量面前,这有点科幻了。
5.如果自动切换出现异常,则系统自动弹窗提示管理员手动切换。如果弹窗也崩了,那就放弃执行,允许按付款减库存的方案销售商品直到库存为零商品下架。

二、运营角度:缩短付款等待期的时间窗长度 +超量备货或减量上架。
0.缩短时间窗长度很好理解,在系统里调整一个时间参数就可以了。
1.超量备货:如果,库存系统的数据可以与实际库存量不一致。那么在促销时,比如系统库存数是1W件,那么实际备货数量就按阙值的两倍,进行超量备货。
2.减量上架:如果,库存系统的数据与实际库存数量必须一致。那么在设置参加活动商品的数量时,比如库存是1W件,那么活动商品就设成9000件。

三、但是这两种方案并行之后,作用只能是减少超卖的规模而非杜绝。
由于网购的特点,非常受制于商品、时间、用户结构等因素,而这些因素很难在一个大型活动前进行全部的、完全精准的预估,所以很难完全杜绝超卖。

四、将开发成本、系统成本,与产品效果对比,判断投入产出比。如果投入产出比不高,就只在运营方面进行调整吧。。。

乐游,总是很想吐槽

超卖一般是秒杀系统设计得不完美。具体来说就是因为短时间内对数据库的操作过于频繁,并发的操作太多,可能有两个或以上的操作同时处理同一件库存,这样就会卖超。

因为秒杀活动的环境跟一般出售商品不同,减库存这种方法是不能依赖的,所以现在设计的秒杀系统基本都不会像上边两位说的靠减库存(这样的话几乎全部会卖超)。一些B2C的秒杀架构是给每个库存一条单独的数据库记录,用一个字段表示“是否售出”。这样很多操作同时进来数据库,只要遍历所有库存,找一个未售出的库存上锁,然后慢慢处理即可。可以大大减少超卖的情况。

淘宝的超卖。。。估计是就算设计成这样还是扛不住巨大的流量吧。。。

任何算法和架构都顶不住巨量的数据这是真理。。。

redis是单线程的,意味着它使用一个主线程来处理所有的请求和操作。尽管在处理请求时会带来一些性能优势,但这也引发了可能的超卖问题超卖问题主要出现在并发访问高峰期,当有多个客户端同时发送大量读写请求时,就可能导致redis的处理速度跟不上请求的到来速度。在这种情况下,由于redis只有一个主线程处理请求,可能会导致请求在等待队列形成排队等待,从而出现超卖问题。 另外,当某个请求需要执行一个特别耗时的操作时,比如一条复杂的查询或者某个任务需要执行很长时间,这个请求会占用redis的主线程,而其他请求必须等待该请求执行完毕才能继续。这也会导致其他请求在等待队列形成排队,从而出现超卖问题。 为了解决redis的超卖问题,可以通过以下几种方式进行优化: 1. 升级硬件:增加服务器的CPU核心数和内存大小,提高redis的处理能力,减少请求在等待队列的排队时间。 2. 增加redis实例:通过在多台服务器上部署多个redis实例,每个实例都有独立的主线程来处理请求,从而增加处理能力。 3. 应用程序层的优化:对于一些耗时的操作,可以将其放到后台线程异步执行,避免阻塞redis的主线程,提高并发处理能力。 4. 使用缓存策略:通过设置适当的缓存策略,将常用的数据缓存在redis,减少对数据库的频繁读写,间接降低了对redis的请求压力。 综上所述,虽然redis是单线程的,但通过一些优化措施可以解决超卖问题,提高redis的并发处理能力。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值