限时秒杀业务及技术实现解决方案

业务介绍

一、首先先了解一下什么是秒杀?

秒杀:就是平台商家通过发布一些超低价格的商品,所有买家在同一时间网上抢购的一种销售方式。由于商品价格低廉,往往一上架就被抢购一空,有时只用一秒钟,所以会被很称为秒杀。

那些秒杀的过程是怎么样的呢?

如下图:

用户在秒杀页面进行点击立即抢购,即是向平台发送了秒杀的请求,平台服务器做出响应、判断库存等,判断用户抢购成功之后系统扣除库存、修改库存数量、生成用户订单、平台进行发货、物流配送等操作。

1. 平台设计秒杀产品的目的

第一:拉新

第二:促活

2. 商户参与秒杀活动的好处

【限时秒杀】频道位于首页icon第一个位置,拥有上百万级流量,是商户流量和转化率最好的频道之一。

参加秒杀活动有以下好处:

二、秒杀业务概述

1. 商城秒杀活动的业务概述

在平台后台创建秒杀活动选择秒杀方式,对应编辑该秒杀方式的设置项,选择参与活动的品牌以及商品,设计参与活动库存等设置具体的秒杀活动规则和投放设置用户在商城查看商品,可看到由平台后台发布的秒杀信息将商品加入购物车,购物车将体现享受秒杀的优惠价格。可在后台查看到已创建的活动以及活动的效果,关于用户购买订单相关的数据也将展示其享受到的秒杀优惠信息。

2. 秒杀系统模块概述

将模块拆分,主要分为三部分:

秒杀活动:活动投放的设置管理,负责提供活动方式和商品内容秒杀规则:发布秒杀活动时选择,负责提供秒杀玩法,例如限时秒杀、品牌专场秒杀等秒杀:提供一种相对独立的促销形式

3. 秒杀系统概述

活动状态:

未开始,还未到活动开始时间,此状态的活动可进行编辑和的删除,删除活动为逻辑删除活动中,正在进行中的活动,此状态的活动不能编辑,只能提前结束,结束之后的活动变更为已失效的状态已失效,已经过了活动结束时间,被删除的以及被取消的活动限时秒杀专场秒杀单个商品秒杀

4. 商户参与流程

5. 注意事项

报名数量:每个商家每24h只能报名1个商品。提交报名后,商品的规格(sku)将被锁定,不可修改。报名通过后,平台会推送活动确认通知,商家需24小时内确认排期和线上库存,确保商品所有规格线上库存都大于活动库存,否者视为自动放弃。不可修改。活动确认后,商品的活动库存和价格将被锁定,秒杀活动期间,商家要时刻关注商品所有规格线上实时库存,及时添加库存,商品某个规格一旦线上库存售罄该规格直接下架无法销售

6. 主要设置项包括

活动名称:方便运营人员识别活动促销方式:专场秒杀、商品秒杀商品选择:参加秒杀的商品((可选择全场、按品类、或者自主选择多个商品)金额/件数设置:秒杀价XX,已售XX,总库存XX投放时间选择:选择开始时间和结束时间打标签:商品打秒杀标识,前端显示秒杀标签,可选择现有标签或者选择自定义新增目标群体: 针对全部用户

7. 具体例子

享受商品价格的活动,这里是秒杀价单品价格1980元计算商品小计之后,引入针对指定专场商品的价格,满2000减250元, 1980*2件-250=3710元累计商品小计价格之后,介入针对于店铺的促销:优惠券优惠券为全品类满1000减200,满足条件,即最终订单价格(免邮)为3710-200=3510元所以最终这笔订单先后享受了三重优惠

 

   什么是秒杀?通俗一点讲就是网络商家为促销等目的组织的网上限时抢购活动

比如说京东秒杀,就是一种定时定量秒杀,在规定的时间内,无论商品是否秒杀完毕,该场次的秒杀活动都会结束。这种秒杀,对时间不是特别严格,只要下手快点,秒中的概率还是比较大的。

淘宝以前就做过一元抢购,一般都是限量 1 件商品,同时价格低到「令人发齿」,这种秒杀一般都在开始时间 1 到 3 秒内就已经抢光了,参与这个秒杀一般都是看运气的,不必太强求

业务特点

瞬时并发量大

秒杀时会有大量用户在同一时间进行抢购,瞬时并发访问量突增 10 倍,甚至 100 倍以上都有。

库存量少

一般秒杀活动商品量很少,这就导致了只有极少量用户能成功购买到。

业务简单

流程比较简单,一般都是下订单、扣库存、支付订单

技术难点

现有业务的冲击

秒杀是营销活动中的一种,如果和其他营销活动应用部署在同一服务器上,肯定会对现有其他活动造成冲击,极端情况下可能导致整个电商系统服务宕机

直接下订单

下单页面是一个正常的 URL 地址,需要控制在秒杀开始前,不能下订单,只能浏览对应活动商品的信息。简单来说,需要 Disable 订单按钮

页面流量突增

秒杀活动开始前后,会有很多用户请求对应商品页面,会造成后台服务器的流量突增,同时对应的网络带宽增加,需要控制商品页面的流量不会对后台服务器、DB、Redis 等组件的造成过大的压力

架构设计思想

限流

由于活动库存量一般都是很少,对应的只有少部分用户才能秒杀成功。所以我们需要限制大部分用户流量,只准少量用户流量进入后端服务器

削峰

秒杀开始的那一瞬间,会有大量用户冲击进来,所以在开始时候会有一个瞬间流量峰值。如何把瞬间的流量峰值变得更平缓,是能否成功设计好秒杀系统的关键因素。实现流量削峰填谷,一般的采用缓存和 MQ 中间件来解决

异步

秒杀其实可以当做高并发系统来处理,在这个时候,可以考虑从业务上做兼容,将同步的业务,设计成异步处理的任务,提高网站的整体可用性

缓存

秒杀系统的瓶颈主要体现在下订单、扣减库存流程中。在这些流程中主要用到 OLTP 的数据库,类似 MySQL、SQLServer、Oracle。由于数据库底层采用 B+ 树的储存结构,对应我们随机写入与读取的效率,相对较低。如果我们把部分业务逻辑迁移到内存的缓存或者 Redis 中,会极大的提高并发效率

整体架构

客户端优化

客户端优化主要有两个问题

秒杀页面

秒杀活动开始前,其实就有很多用户访问该页面了。如果这个页面的一些资源,比如 CSS、JS、图片、商品详情等,都访问后端服务器,甚至 DB 的话,服务肯定会出现不可用的情况。所以一般我们会把这个页面整体进行静态化,并将页面静态化之后的页面分发到 CDN 边缘节点上,起到压力分散的作用

防止提前下单

防止提前下单主要是在静态化页面中加入一个 JS 文件引用,该 JS 文件包含活动是否开始的标记以及开始时的动态下单页面的 URL 参数。同时,这个 JS 文件是不会被 CDN 系统缓存的,会一直请求后端服务的,所以这个 JS 文件一定要很小。当活动快开始的时候(比如提前),通过后台接口修改这个 JS 文件使之生效

API 接入层优化

客户端优化,对于不是搞计算机方面的用户还是可以防止住的。但是稍有一定网络基础的用户就起不到作用了,因此服务端也需要加些对应控制,不能信任客户端的任何操作。一般控制分为 2 大类

限制用户维度访问频率

针对同一个用户( Userid 维度),做页面级别缓存,单元时间内的请求,统一走缓存,返回同一个页面

限制商品维度访问频率

大量请求同时间段查询同一个商品时,可以做页面级别缓存,不管下回是谁来访问,只要是这个页面就直接返回

SOA 服务层优化

上面两层只能限制异常用户访问,如果秒杀活动运营的比较好,很多用户都参加了,就会造成系统压力过大甚至宕机,因此需要后端流量控制

对于后端系统的控制可以通过消息队列、异步处理、提高并发等方式解决。对于超过系统水位线的请求,直接采取 「Fail-Fast」原则,拒绝掉

秒杀整体流程图

秒杀系统核心在于层层过滤,逐渐递减瞬时访问压力,减少最终对数据库的冲击。通过上面流程图就会发现压力最大的地方在哪里?

MQ 排队服务,只要 MQ 排队服务顶住,后面下订单与扣减库存的压力都是自己能控制的,根据数据库的压力,可以定制化创建订单消费者的数量,避免出现消费者数据量过多,导致数据库压力过大或者直接宕机。

库存服务专门为秒杀的商品提供库存管理,实现提前锁定库存,避免超卖的现象。同时,通过超时处理任务发现已抢到商品,但未付款的订单,并在规定付款时间后,处理这些订单,将恢复订单商品对应的库存量

总结

核心思想:层层过滤

  • 尽量将请求拦截在上游,降低下游的压力
  • 充分利用缓存与消息队列,提高请求处理速度以及削峰填谷的作用

参考

秒杀架构设计 | IT瘾秒杀架构设计,dev , IT社区推荐资讯 icon-default.png?t=M4ADhttp://itindex.net/detail/58166秒杀业务架构优化之路_DevOps_沈剑_InfoQ精选文章秒杀业务架构优化之路本文整理自“ArchSummit微课堂”线上分享——沈剑解析秒杀业务架构优化的思路。一、秒杀业务为什https://www.infoq.cn/article/flash-deal-architecture-optimization秒杀业务介绍_xiaoyingyings的博客-CSDN博客_秒杀动态url秒杀系统的实现秒杀的概念使用技术点优化和预防参考地址一、概念所谓“秒杀”,就是网络卖家发布一些超低价格的商品,所有买家在同一时间网上抢购的一种销售模式。通俗一点就是网络商家为促销等目的组织的网上限时抢购活动。由于商品价格低廉,往往已上架就被抢购一空,有时只用一秒钟。相关业务场景:淘宝京东双11秒杀、日常秒杀活动;12306抢票特点:1、特定时间内,用户同一时间进行抢购,网站流量激增;2、秒杀请求数量远远大于库存量;3、抢购支付成功从数据库减少库存注意点:高并发、超卖、接口防刷https://blog.csdn.net/xiaoyingyings/article/details/123211879

高并发秒杀系统架构设计 · 抢购、微信红包、一元夺宝 - 知乎秒杀业务与难点秒杀业务在各业务中已然非常流行,这里我将互联网行业中的秒杀定义为:在非常短的时间内,将一件商品分成多份进行购买的行为。微信抢红包、 一元夺宝、双11大促抢购等业务本质上都可视作秒杀业务。…https://zhuanlan.zhihu.com/p/25368538互联网秒杀设计_wx60ebfae30b477的技术博客_51CTO博客互联网秒杀设计,抢购、闪购,从国外风靡后,国内各类网站都开始做相似的业务,我们耳熟能详的唯品会、淘宝、https://blog.51cto.com/u_15300891/3062059

 

  • 0
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值