范文健康探索娱乐情感热点
投稿投诉
热点动态
科技财经
情感日志
励志美文
娱乐时尚
游戏搞笑
探索旅游
历史星座
健康养生
美丽育儿
范文作文
教案论文
国学影视

亿级用户的秒杀系统设计

  以下文章来源于二马读书 ,作者二马读书
  个人从事电商行业十几年,经历过大大小小的促销活动和秒杀上百次,每次做秒杀瞬时访问量会翻数十倍,甚至数百倍。对系统架构是巨大的考验,期间也曾经历过系统宕机,甚至整体雪崩。那么我们怎么设计秒杀系统,才能保证秒杀系统的高性能和稳定性,同时还要保证日常业务不受影响呢?
  先看看秒杀场景特点。秒杀开始前几分钟,大量用户开始进入秒杀商品详情页面,很多人开始频繁刷新秒杀商品详情页,这时秒杀商品详情页访问量会猛增。秒杀开始,大量用户开始抢购,这时创建订单,扣库存压力会显著增大。实际上,秒杀场景基本都是秒杀参与人多,秒杀成功的人却寥寥无几,经常是几十万人或者更多人抢几百个商品库存。
  那么我们曾经是怎么设计秒杀系统的呢?主要涉及以下几个方面:
  秒杀业务流程上的考虑:
  由于参加秒杀的商品售卖价格非常低,基本都是"抢到即赚到",成功下单后却不付款的情况非常少。所以我们采用下单减库存的方案,下单时扣减库存,然后再进行支付。假如真有个别订单不付款怎么办?没关系,秒杀好活动最主要的目的是吸引流量,个别订单不支付对秒杀活动本身影响不大。况且,没支付剩下的库存还可以做为普通商品继续售卖。不过要注意对机器人和自动脚本的防御,后面会详细介绍。
  页面静态化:
  "秒杀开始前几分钟,大量用户开始进入秒杀商品详情页面,很多人开始频繁刷新秒杀商品详情页,这时秒杀商品详情页访问量会猛增"。如果请求全部打到后端服务,那后端服务的压力会非常大(后端服务要处理业务逻辑,而且还要访问数据库,吞吐量比较低)。
  考虑到秒杀是运营同学提前安排的活动,要秒杀哪些商品、商品价格等信息在秒杀活动开始前已经确定下来,所以我们可以把秒杀商品详情页做成静态页面,把商品详情、商品价格等参数、评论评价等信息全部放在这个静态页面里,然后把这个静态页面上传到CDN上预热(CDN是内容分发网络,可以简单理解成互联网上的巨大的缓存,用于存放静态页面、图片、视频等,可以显著提高访问速度),用CDN扛流量,这样大量的商品详情页的访问请求就不用访问自己的网站(源站)。这样既可以提高访问速度,也没有给网站增加压力,同时也减少了网站带宽压力。
  请求拦截:
  前端页面,相关按钮点击后置灰,防止重复提交
  网关(zuul,nginx)层,为了避免前端恶意请求,比如一些攻击脚本,在网关层要对下单等接口按userID限流,几秒钟只能访问一次。考虑到秒杀场景参与人多,秒杀成功的人极少,我们可以把绝大部分抢购下单请求在网关层直接拒掉,按秒杀失败处理。这样就极大减少了后端服务的压力。
  假设秒杀库存是200个,我们可以只放行200个请求到后端服务。要注意,为了尽量避免库存被机器人和自动脚本抢走,200个请求不能在秒杀开始瞬间同时放行,可以分段放行,比如秒杀开始后随机选取100ms内的5个请求放行(这100ms内的其他请求直接拒掉,按秒杀失败处理),之后每隔100ms放行5个请求,4秒钟可以放行完200个请求。分段放行,除了限制了机器人和自动脚本,把请求分散在各个时间段,还进一步缓解了后端服务的压力。
  分段放行总时间不能太长,假如每100ms放行1个请求,放行完所有200个请求需要20秒时间,这样用户就会明显感知到下单早的人没秒杀成功,下单晚的人反而秒杀成功了,用户体验会变差。
  另外,秒杀过程网关压力会比较大,网关可以做成集群,多节点分摊访问压力。
  后端服务设计:
  如果秒杀库存只有200,经过网关拦截,再加上采用分段放行的方式,对于后端服务基本没什么压力了,日常的后端服务就完全可以支撑秒杀活动了。不用再做更复杂的设计。不过,假如秒杀库存有几万个,放行的下单请求就有几万个,为了用户体验放行总时间也不能太长,这时后端服务该怎么设计呢?
  这时主要压力就在数据库了,扣减库存压力,创建订单压力。
  库存可以放到Reids缓存中,来提高扣减库存吞吐能力。对于热点商品的库存可以利用Redis分片存储。
  创建订单可以走异步消息队列。后端服务接到下单请求,直接放进消息队列,监听服务取出消息后,先将订单信息写入Redis,每隔100ms或者积攒100条订单,批量写入数据库一次。前端页面下单后定时向后端拉取订单信息,获取到订单信息后跳转到支付页面。用这种批量异步写入数据库的方式大幅减少了数据库写入频次,从而明显降低了订单数据库写入压力。
  隔离:
  1,业务隔离。从业务上把秒杀和日常的售卖区分开来,把秒杀做为营销活动,要参与秒杀的商品需要提前报名参加活动,这样我们就能提前知道哪些商家哪些商品要参与秒杀,可以根据提报的商品提前生成静态页面并上传到CDN预热,提报的商品库存也需要提前预热,可以将商品库存在活动开始前预热到Redis,避免秒杀开始后大量的缓存穿透。
  2,部署隔离。秒杀相关服务和日常服务要分组部署,不能因为秒杀出问题影响日常售卖业务。可以申请单独的秒杀域名,从网络入口层就开始分流。网关也单独部署,秒杀走自己单独的网关,从而避免日常网关受到影响。秒杀可以复用订单,库存,支付等日常服务,只是需要一些小的改造(比如下单流程走消息队列,批量写入订单库,以及在Redis中扣减库存)。
  3,数据隔离。为了避免秒杀活动影响到日常售卖业务,Redis缓存需要单独部署,甚至数据库也需要单独部署!数据隔离后,秒杀剩余的库存怎么办?秒杀活动结束后,剩余库存可以归还到日常库存继续做为普通商品售卖。数据隔离后,秒杀订单和日常订单不在相同的数据库,之后的订单查询怎么展示?可以在创建秒杀订单后发消息到消息队列,日常订单服务采取拉的方式消费消息,这时日常订单服务是主动方,可以采用线程池的方式,根据机器的性能来增加或缩小线程池的大小,控制拉取消息的速度,来控制订单数据库的写入压力。
  网络:
  秒杀前要和网络运营商、CDN服务商提前申请带宽。
  还有哪些细节要考虑:
  如何避免超卖?如果在redis中扣减库存,可以利用decr命令扣减库存,decr是原子操作,在分布式环境下也不会有并发问题,decr扣减库存后,判断返回值,如果返回值小于0,扣减库存失败,秒杀也就失败了;如果在数据库中扣减库存可以在where后面加上库存大于0的条件,来避免库存被减成负值。这样就可以避免超卖情况发生了。
  接口防刷,前面已经提到过,在网关层对下单等接口按userID限流。
  网关层除了对userID做限流外,还要做整体限流。在实际访问量超过预估访问量时,整体限流可以起到保护作用,避免系统被压垮。
  防止重复下单,按userID限流已经起到了防止重复下单的作用。假如限制同一个用户10分钟能下一次单,一般情况下10分钟内,商品早已经被抢光了,用户也就没有再次下单的机会了。
  可以结合风控系统,在网关层把羊毛党等有问题的用户请求直接拒掉。
  可以在网关层上面再加一层防火墙或者高防服务,来防御DDos等分布式网络攻击。
  好啦,就分享到这里。如果感觉本文对您有帮助,有劳动动手指转发一下,分享是美德哦

ampampquot善有善报恶有恶报ampampquot有科学根据?如果是真的我就放心了传统固有的人生训诲,强调善有善报恶有恶报,但这样的教诲,在科学昌明的今日社会,难道只能一种道德教条,无法以科学方法来证实吗?直到看到心理学家大卫R。霍金斯在其着的Powervs。F亚洲十大考古未解之谜,中国比贡山铁管排第三亚洲是许多伟大的考古奇迹的发源地,比如中国的长城和失落的佩特拉古城。在考古学和科学的帮助下,许多古老的世界奇迹被完全破解,对古代文明的历史技术和生活提供宝贵的洞察力。然而,有一些还中国历史上十大神秘黄帝陵,有的庞大,有的至今没找到秦始皇陵堪称内涵最丰富公元前246年,秦始皇开始在今天的陕西省临潼区骊山脚下建造一座堪称是世界上规模最大结构最奇特内涵最丰富的帝王陵墓,在以后的2000多年时间里,围绕着这座神奇的一夫二妻,三个男人结婚,4个人凑成了5对,世界之大无奇不有1。双胞胎爱上同一个男人,做手术让二人看起来更像珀斯居民Anna和LucyDeCinque是同卵双胞胎,她们的所有都是共享的工作汽车甚至男人BenByrne。她们还想变得跟彼此更像天才在左,疯子在右这些熟知的天才竟然有抑郁症自闭症NO。1亚伯拉罕林肯(AbrahamLincoln)抑郁症在美国人心目中,没有人能代替亚伯拉罕林肯的位置。多年来,林肯始终在最受美国人爱戴的总统评选中稳居第一。对美国人来说,林肯是盘点个人最喜欢的几部经典电影,符合您心目中的十佳影片吗TOP1肖申克的救赎TheShawshankRedemption月黑高飞(港)刺激1995(台)导演弗兰克德拉邦特FrankDarabont主演蒂姆罗宾斯TimRobbins199中国古代十大未解之谜,历史遗留下来的谜题和遗憾中国历史源远流长,光是正史野史有名有姓的史书就无法数的清楚。然而历史也给我们留下了很多困惑和遗憾。我们且来说说中国古代十大未解之谜都有什么呢?完璧归赵的故事人人尽知,传说这块宝玉能经济快速发展的同时,当今中国社会最缺的十样东西?改革开放以来,中国经济发生巨大变化,但有些宝贵的东西,随着时代的变迁却丢失了。反思中国发生的食品安全问题医疗问题教育问题贪污腐败问题等,无一不与我们缺失的这几样东西相关。1感恩缺失盘点目前中国市场上几个暴利行业,要改行了,还有其他的吗?当下市场,仍不乏处于巨大需求缺口的行业。许多人怀着一夜暴富的梦想匆匆闯入,有的人赚到盆满钵满,有的人则输得倾家荡产。暴利行业依然存在,可利润与风险共存,唯有时刻保持清醒的头脑存有危关于地球上的十四个未解之谜?我们赖以生存的地球,是它在无私的养育着我们这千千万万的人,然而我们对它却还不够熟悉,它身上隐藏的秘密,它曾经的伤痛我们不曾去发觉,今天小编就为你揭开地球这位世上最伟大母亲的神秘面纱看看古人为达目的,使用的那些手段。瞬间觉得小巫见大巫借刀杀人魏王送楚怀王一绝色美女魏姬。宠妃郑袖不但不嫉妒,还待魏姬特别好,魏姬不由感恩戴德。楚怀王看在眼里,也称赞郑袖的贤德不妒。时机成熟后,郑袖便神秘兮兮对魏姬说,楚怀王不喜欢魏姬
灌篮高手深度八一八隐藏在灌篮高手漫画中的那些小细节(七)各位,好久不见啦为了能在这一期给大家截到光叔模仿狐狸叫声的音频,小编特意回顾了一下灌篮高手的TV版,所以这才耽误了整个的进度想知道流川的狐狸叫声是什么样子的吗?那么我们就开始今天的灌篮高手深度八一八隐藏在灌篮高手漫画中的那些小细节(九)Hi小编我又回来啦在这一期的开头,我们先做两个回顾首先,我们先补上上一期没办法添加进来的音频或许,我根本不是一个天才音频原文俺()天才()其次我们再来回顾一下月野兔这张图大红大绿配新生儿承受的太多脸上长出奇怪白斑,医生买来的奶粉有问题星星才16个月,脸上的白斑却占据小脸的一半,让人看着很是心疼,星星看着我们笑了笑,脸上没有一点悲伤,可是我们所有人看着孩子眼泪在眼里打转,这么小的年纪就要承受白癜风的困恼,年轻的父中国古代文化之职官这里说的职官主要是指各朝各代的官职的称呼,因为历史的变迁,很多官位的称呼有很大的变化,简易的分为三类中央官制地方官制和品阶勋爵。中央官制从春秋战国时期,当时分别设相和将,分掌文武,关于财富的秘密,这篇文章可能颠覆你的认知古希腊哲学家赫拉克利特说万物流转。佛法说诸行无常。老子在道德经中说道可道,非常道。名可名,非常名。这些话表达的是同一个意思天地间唯一不变的就是变。这似乎是个真理世界上永恒不变的,就给予,是拥有一切的秘密在你修行与成长的道路上,有一条宇宙法则你一定要明白给予,是一切丰盛的源头,给予,才能丰盛的拥有。这个宇宙中,有作为果相的有形的宇宙,还有创造这个果相宇宙背后的源头宇宙,我把源头宇宙欧阳修的成长经历,揭示了孩子成才的大秘密作为唐宋八大家的欧阳修,是如何成为杰出的文学家和政治家的呢?欧阳修的母亲用了四个字教育孩子,揭示了成才的秘密!欧阳修四岁的时候,父亲去世了,母亲一人带着小欧阳修来到了大叔父家,结果儿童身高发育的误区,你中招了没?每个家长,都希望自己的孩子能高大英俊亭亭玉立。为了让孩子长高,将来能拥有大长腿,父母们不断收集着各种长高秘诀。但这其中不乏谣言和误区,陷入这些误区中,反而可能耽误孩子的生长发育!生最彻底的治病,是解开心灵的枷锁身体其实是我们与内在之间的交流工具。它不只是供我们居住的躯壳,它还拥有一套聪明的运行机制,可以帮助内在表达,了解自身的问题。而疾病的出现有着提示的作用,它向你指出那些需要疗愈的地方你拥有的最伟大的能力,就是治愈自己人的一生,就是在找寻自己最深层面的真实面貌。生命中那些使你挣扎奋斗的让你痛苦的每个情境,都是让你学习如何真实的进一步向灵魂靠近。寻找真实,意味着一切由真心而启,更靠近你的灵魂将光带语言暗示出的能量,能深刻改变你的未来01hr从与自己好好讲话开始我们说出来的话对生活有很大的影响,大部分人都没意识到这点。我们说出来的话是建设生命的基础,我们一直在说话却很少思考自己说话的方式或说了些什么,实际上我们