秒杀系统优化思路

author author     2022-10-06     396

关键词:

一、秒杀业务为什么这么难做

秒杀系统,库存只有一份,所有人会在集中的时间读和写这些数据。

例如:

  • 小米手机每周二的秒杀,可能手机只有1万部,但瞬间进入的流量可能是几百几千万。
  • 12306抢票,票是有限的,但是抢票的人很多,都读取相同的库存。读写冲突,锁非常严重,这是业务难的地方。

那我们怎么优化秒杀业务呢?

二、优化方向

(以上的两个场景要优化有两个方向)

  • 将请求尽量拦截在系统上游(不要让锁冲突落到数据库上去)。传统的秒杀系统之所以挂,是因为请求都压到后端数据层,数据读写冲突严重,并发高响应慢,几乎所有请求都超时,流量最大,下单成功的有效流量非常小。以12306为例,一趟火车其实只有2000张票,但是抢到的人却有200万,基本没人能买票成功,请求有效率为0.
  • 充分利用缓存,秒杀买票,这是一个典型的读多写少的应用场景,大部分请求是车次/票查询,下单和支付才是写请求。一趟火车只有2000张票,200万人来买,最多2000人下单成功,其他人都是查库存,写入操作的比例是0.1%,而读取的操作比例是99.9%,非常适合缓存来做优化。

三、常见秒杀架构

常见的秒杀架构基本是这样的

         技术分享图片

  • 浏览器端,最上层,会执行一些JS代码
  • 站点层,这一层会访问后端数据,将操作响应返回给浏览器
  • 服务层,向上游屏蔽底层数据细节,提供数据访问
  • 数据层,最终的“库存”会存放在这里,mysql是一个典型(当然还有缓存),这张图虽然简单,但是能形象的说明大流量高并发的秒杀业务架构(根据笔者从业的经验,基本所有公司的软件架构都脱离不了这几层,大同小异),后面详细解  析各层级怎么优化。

四、各层优化细节

  • 第一层:客户端怎么优化(浏览器层,APP层)

    大家应该都玩过微信摇一摇抢红包,是每一次摇一摇,就会往后端发送请求么?

    回顾一下我们12306刚出来那年抢票的场景,点击“查询”按钮之后,系统卡在那里或者响应非常慢,这时用户就会再次点击”查询“,继续点点点,可是这样有用么?徙增系统负载,如果真实购买用户只有200W,那一个用户多点击5次,

    就有1000万,多出来80%的用户怎么整?

    • 产品层面优化:用户点击查询或者购票操作后,按钮置灰,禁止用户重复提交。
    • JS层面优化:限制用户在x秒内只能提交一次请求。

    上面说到摇红包,就算我们疯狂的把手机甩飞了,系统也只是在x秒才向系统发送请求。

    这就是所谓的“将请求尽量拦截在系统上游”,越上游越好,浏览器层,APP层就给拦住,这样就挡住了多出那80%的用户请求。

    但是,这种办法只能拦截住普通的用户,对于高端的程序猿们来说是拦不住的,firebug一抓包,http长啥样都知道了,js是拦不住程序员写for循环调用http接口的,这部分请求如何处理?

 

  • 第二层:站点层面的请求拦截

    怎么防止程序猿们for循环请求呢?有去重依据么?ip?cookie-id?这类“秒杀”业务都需要登录,用我们加了密的uid即可。在站点层面,对uid进行请求计数和去重,一个uid在5秒内只允许1个请求(例如生成uid时加入时间戳),

    这样就可以拦截住程序猿们的for循环请求。

    5秒只透过一个请求,那其他请求怎么办?缓存,页面缓存,同一个uid访问频度做页面缓存,x秒内到达站点请求,均返回同一个页面。 如此限流,既能保证用户体验又能保证系统的健壮性。

    (页面缓存不一定要保证所有站点返回一致的页面,直接放在每个站点的内存也可以,优点是简单。缺点是http请求落到不同的站点,返回的车票数据可能不一样。)

    这是站点层请求拦截和缓存的优化

    如果,有黑客控制了10万个肉鸡,不同的uid,同时发送请求的话,我们怎么办?站点层按照uid限流已经拦截不住了。

 

  • 第三层:服务层拦截

  (反正不要让请求落到数据层上)

    服务层如何来拦截呢?请求队列,对于写入操作的请求,每次只透有限的请求去数据层,这个有限取决于有多少部小米手机或多少张火车票。如果库存不够则全部返回“已售完”。

    对于读取的请求如何优化?用cache抗 ,不管是mecached还是redis,单机抗个每秒10万都没问题,如此限流,只有非常少的写入请求,和非常少的读取缓存mis的请求会透到数据层去,又有99.9%的请求被拦住了。

 

  • 第四层:数据层

    浏览器拦截了80%,站点层拦截了99.9%并做了页面缓存,服务层又做了请求队列与数据缓存,每次透到数据层的请求都是可控的。db基本没什么压力了,还是那句话,库存是有限的,透这么多请求来数据库没有意义。

    全部透到数据库,100万个下单,0个成功,透3000到数据库,全部成功。请求有效率为100%。

总结:

  再重复一下关于秒杀系统的两个优化思路:

  • 尽量将请求拦截在系统上游(越上游越好)
  • 读多写少的应用多使用缓存(缓存抗读压力)
  • 浏览器和APP:做限速
  • 站点层:按照uid限速,做页面缓存
  • 服务器:按照业务做写请求队列控制流量,做数据缓存
  • 数据层:闲庭信步
  • 并且结合业务做优化。

 

文章内容来源于微信公众号“架构师之路”,欢迎大家关注。

我在文章中看到了几个技术点:memcache请求队列。有时间我好好研究一下,再整理到自己的博客上。

 

如果大家有什么好的想法,可以留言,我肯定会学习并实践好再拿出来分享。

非常感谢。

如果对您有帮助,请点赞!

秒杀系统架构优化思路

秒杀系统架构优化思路本文曾在“架构师之路”上发布过,近期支援Qcon-AS大会,在微信群里分享了该话题,故对原文进行重新整理与发布。 一、秒杀业务为什么难做1)im系统,例如qq或者微博,每个人都读自己的数据(好友... 查看详情

秒杀系统架构优化思路

一、秒杀业务为什么难做1)im系统,例如qq或者微博,每个人都读自己的数据(好友列表、群列表、个人信息);2)微博系统,每个人读你关注的人的数据,一个人读多个人的数据;3)秒杀系统,库存只有一份,所有人会在集... 查看详情

秒杀系统架构优化思路

一、为什么难秒杀系统难做的原因:库存只有一份,所有人会在集中的时间读和写这些数据。例如小米手机每周二的秒杀,可能手机只有1万部,但瞬时进入的流量可能是几百几千万。又例如12306抢票,亦与秒杀类似,瞬时流量更... 查看详情

阿里秒杀系统架构优化思路

秒杀业务为什么难做im系统,例如qq或者微博,每个人都读自己的数据(好友列表、群列表、个人信息)微博系统,每个人读你关注的人的数据,一个人读多个人的数据秒杀系统,库存只有一份,所有人会在集中的时间读和写这... 查看详情

转载秒杀系统架构优化思路

...分享了该话题,故对原文进行重新整理与发布。 一、秒杀业务为什么难做1)im系统,例如qq或者微博,每个人都读自己的数据(好友列表、群列表、个人信息);2)微博系统,每个人读你关注的人的数据,一个人读多个人的... 查看详情

秒杀抢购系统优化思路详解

前几年,火车票购票网站12306,每到放假高峰期,在线票刷不出来,购买困难,甚至出现了各种插件支持抢票,这样的场景,对于每个买过票的人,应该印象深刻。小米手机的抢购活动,同样异常火爆,在几分钟的时间内,卖出... 查看详情

关于秒杀的系统架构优化思路

一、问题的提出秒杀或抢购活动一般会经过预约,下单,支付,扛不住的地方在于下单,一般会带来2个问题:1、高并发比较火热的秒杀在线人数都是10w起的,如此之高的在线人数对于网站架构从前到后都是一种考验。2、超卖任... 查看详情

秒杀系统架构优化思路

...分享了该话题,故对原文进行重新整理与发布。一、秒杀业务为什么难做1)im系统,例如qq或者微博,每个人都读自己的数据(好友列表、群列表、个人信息);2)微博系统,每个人读你关注 查看详情

58沈剑架构系列秒杀系统架构优化思路

一、秒杀业务为什么难做1)im系统,例如qq或者微博,每个人都读自己的数据(好友列表、群列表、个人信息);2)微博系统,每个人读你关注的人的数据,一个人读多个人的数据;3)秒杀系统,库存只有一份,所有人会在集... 查看详情

秒杀系统架构优化思路

...分享了该话题,故对原文进行重新整理与发布。一、秒杀业务为什么难做1)im系统,例如qq或者微博,每个人都读自己的数据(好友列表、群列表、个人信息);2)微博系统,每个人读你关注的... 查看详情

“秒杀系统优化思路”记录

...0c;导致现在已经有点臃肿了。。。文章目录优化方向常见秒杀架构及各层次优化细节目前我的做法优化方向优化方向有两个:1、将请求尽量拦截在上游2、充分利用缓存常见秒杀架构及各层次优化细节1、客户端层:防抖2... 查看详情

优惠卷秒杀系统设计秒杀优化——基于阻塞队实现异步秒杀优化及基于lua脚本判断秒杀库存一人一单(代码片段)

(目录)秒杀优化1、秒杀优化-异步秒杀思路回顾一下下单流程:分成如下几个步骤:在这六步操作中,又有很多操作是要去操作数据库的,而且还是一个线程串行执行,这样就会导致我们的程序执行的很慢,所以我们需要异步程... 查看详情

java秒杀实战服务级高并发秒杀优化(rabbitmq+接口优化)

...中4.请求出队,生成订单,减少库存5.客户端轮询,是否秒杀成功二、安装 查看详情

电商网站秒杀与抢购的系统架构

...来的挑战在过去的工作中,我曾经面对过5w每秒的高并发秒杀功能,在这个过程中,整个Web系统遇到了很多的问题和挑战。如果Web系统不做针对性的优化,会轻而易举地陷入到异常状态。我们现在一起来讨论下,优化的思路和方... 查看详情

秒杀系统设计优化(代码片段)

...相同的库存,读写冲突,锁非常严重;小米手机每周二的秒杀,可能手机只有1万部,但瞬时进入的流量可能是几百几千万;这是秒杀业务难的地方。那我们怎么优化秒杀系统呢?一、难点(1)高并发用户在秒杀开始前,通过不... 查看详情

c#怎么使用redis实现秒杀功能

大概思路吧:秒杀系统的架构设计秒杀系统,是典型的短时大量突发访问类问题。对这类问题,有三种优化性能的思路: 写入内存而不是写入硬盘 异步处理而不是同步处理 分布式处理 用上这三招,不论秒杀时负... 查看详情

秒杀/抢购系统设计优化

...相同的库存,读写冲突,锁非常严重;小米手机每周二的秒杀,可能手机只有1万部,但瞬时进入的流量可能是几百几千万;这是秒杀业务难的地方。那我们怎么优化秒杀系统呢?一、难点(1)高并发用户在秒杀开始前,通过不... 查看详情

电商 秒杀系统 设计思路和实现方法(代码片段)

电商 秒杀系统 设计思路和实现方法2017年05月26日00:06:35阅读数:36621秒杀业务分析正常电子商务流程(1)查询商品;(2)创建订单;(3)扣减库存;(4)更新订单;(5)付款;(6)卖家发货秒杀业务的特性(1)低廉价格... 查看详情